mirror of
https://github.com/nushell/nushell
synced 2025-01-14 22:24:54 +00:00
Rename 'bytes' to 'filesize' (#2153)
This commit is contained in:
parent
1bb6a2d9ed
commit
0bc2e29f99
25 changed files with 78 additions and 76 deletions
|
@ -357,12 +357,12 @@ impl From<DirInfo> for Value {
|
||||||
|
|
||||||
r.insert(
|
r.insert(
|
||||||
"apparent".to_string(),
|
"apparent".to_string(),
|
||||||
UntaggedValue::bytes(d.size).into_value(&d.tag),
|
UntaggedValue::filesize(d.size).into_value(&d.tag),
|
||||||
);
|
);
|
||||||
|
|
||||||
r.insert(
|
r.insert(
|
||||||
"physical".to_string(),
|
"physical".to_string(),
|
||||||
UntaggedValue::bytes(d.blocks).into_value(&d.tag),
|
UntaggedValue::filesize(d.blocks).into_value(&d.tag),
|
||||||
);
|
);
|
||||||
|
|
||||||
r.insert("directories".to_string(), value_from_vec(d.dirs, &d.tag));
|
r.insert("directories".to_string(), value_from_vec(d.dirs, &d.tag));
|
||||||
|
@ -399,12 +399,12 @@ impl From<FileInfo> for Value {
|
||||||
|
|
||||||
r.insert(
|
r.insert(
|
||||||
"apparent".to_string(),
|
"apparent".to_string(),
|
||||||
UntaggedValue::bytes(f.size).into_value(&f.tag),
|
UntaggedValue::filesize(f.size).into_value(&f.tag),
|
||||||
);
|
);
|
||||||
|
|
||||||
let b = f
|
let b = f
|
||||||
.blocks
|
.blocks
|
||||||
.map(UntaggedValue::bytes)
|
.map(UntaggedValue::filesize)
|
||||||
.unwrap_or_else(UntaggedValue::nothing)
|
.unwrap_or_else(UntaggedValue::nothing)
|
||||||
.into_value(&f.tag);
|
.into_value(&f.tag);
|
||||||
|
|
||||||
|
|
|
@ -71,7 +71,7 @@ pub fn average(values: &[Value], name: &Tag) -> Result<Value, ShellError> {
|
||||||
|
|
||||||
match total {
|
match total {
|
||||||
Value {
|
Value {
|
||||||
value: UntaggedValue::Primitive(Primitive::Bytes(num)),
|
value: UntaggedValue::Primitive(Primitive::Filesize(num)),
|
||||||
..
|
..
|
||||||
} => {
|
} => {
|
||||||
let left = UntaggedValue::from(Primitive::Int(num.into()));
|
let left = UntaggedValue::from(Primitive::Int(num.into()));
|
||||||
|
@ -81,7 +81,7 @@ pub fn average(values: &[Value], name: &Tag) -> Result<Value, ShellError> {
|
||||||
Ok(UntaggedValue::Primitive(Primitive::Decimal(result))) => {
|
Ok(UntaggedValue::Primitive(Primitive::Decimal(result))) => {
|
||||||
let number = Number::Decimal(result);
|
let number = Number::Decimal(result);
|
||||||
let number = convert_number_to_u64(&number);
|
let number = convert_number_to_u64(&number);
|
||||||
Ok(UntaggedValue::bytes(number).into_value(name))
|
Ok(UntaggedValue::filesize(number).into_value(name))
|
||||||
}
|
}
|
||||||
Ok(_) => Err(ShellError::labeled_error(
|
Ok(_) => Err(ShellError::labeled_error(
|
||||||
"could not calculate average of non-integer or unrelated types",
|
"could not calculate average of non-integer or unrelated types",
|
||||||
|
|
|
@ -134,7 +134,7 @@ fn compute_average(values: &[Value], name: impl Into<Tag>) -> Result<Value, Shel
|
||||||
|
|
||||||
match total {
|
match total {
|
||||||
Value {
|
Value {
|
||||||
value: UntaggedValue::Primitive(Primitive::Bytes(num)),
|
value: UntaggedValue::Primitive(Primitive::Filesize(num)),
|
||||||
..
|
..
|
||||||
} => {
|
} => {
|
||||||
let left = UntaggedValue::from(Primitive::Int(num.into()));
|
let left = UntaggedValue::from(Primitive::Int(num.into()));
|
||||||
|
@ -144,7 +144,7 @@ fn compute_average(values: &[Value], name: impl Into<Tag>) -> Result<Value, Shel
|
||||||
Ok(UntaggedValue::Primitive(Primitive::Decimal(result))) => {
|
Ok(UntaggedValue::Primitive(Primitive::Decimal(result))) => {
|
||||||
let number = Number::Decimal(result);
|
let number = Number::Decimal(result);
|
||||||
let number = convert_number_to_u64(&number);
|
let number = convert_number_to_u64(&number);
|
||||||
Ok(UntaggedValue::bytes(number).into_value(name))
|
Ok(UntaggedValue::filesize(number).into_value(name))
|
||||||
}
|
}
|
||||||
Ok(_) => Err(ShellError::labeled_error(
|
Ok(_) => Err(ShellError::labeled_error(
|
||||||
"could not calculate median of non-numeric or unrelated types",
|
"could not calculate median of non-numeric or unrelated types",
|
||||||
|
|
|
@ -41,7 +41,7 @@ pub fn value_to_bson_value(v: &Value) -> Result<Bson, ShellError> {
|
||||||
Ok(match &v.value {
|
Ok(match &v.value {
|
||||||
UntaggedValue::Primitive(Primitive::Boolean(b)) => Bson::Boolean(*b),
|
UntaggedValue::Primitive(Primitive::Boolean(b)) => Bson::Boolean(*b),
|
||||||
// FIXME: What about really big decimals?
|
// FIXME: What about really big decimals?
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(decimal)) => Bson::FloatingPoint(
|
UntaggedValue::Primitive(Primitive::Filesize(decimal)) => Bson::FloatingPoint(
|
||||||
(decimal)
|
(decimal)
|
||||||
.to_f64()
|
.to_f64()
|
||||||
.expect("Unimplemented BUG: What about big decimals?"),
|
.expect("Unimplemented BUG: What about big decimals?"),
|
||||||
|
|
|
@ -115,8 +115,8 @@ pub fn clone_tagged_value(v: &Value) -> Value {
|
||||||
UntaggedValue::Primitive(Primitive::Path(x)) => {
|
UntaggedValue::Primitive(Primitive::Path(x)) => {
|
||||||
UntaggedValue::Primitive(Primitive::Path(x.clone()))
|
UntaggedValue::Primitive(Primitive::Path(x.clone()))
|
||||||
}
|
}
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(b)) => {
|
UntaggedValue::Primitive(Primitive::Filesize(b)) => {
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(*b))
|
UntaggedValue::Primitive(Primitive::Filesize(*b))
|
||||||
}
|
}
|
||||||
UntaggedValue::Primitive(Primitive::Date(d)) => {
|
UntaggedValue::Primitive(Primitive::Date(d)) => {
|
||||||
UntaggedValue::Primitive(Primitive::Date(*d))
|
UntaggedValue::Primitive(Primitive::Date(*d))
|
||||||
|
@ -134,7 +134,7 @@ fn to_string_tagged_value(v: &Value) -> Result<String, ShellError> {
|
||||||
match &v.value {
|
match &v.value {
|
||||||
UntaggedValue::Primitive(Primitive::String(_))
|
UntaggedValue::Primitive(Primitive::String(_))
|
||||||
| UntaggedValue::Primitive(Primitive::Line(_))
|
| UntaggedValue::Primitive(Primitive::Line(_))
|
||||||
| UntaggedValue::Primitive(Primitive::Bytes(_))
|
| UntaggedValue::Primitive(Primitive::Filesize(_))
|
||||||
| UntaggedValue::Primitive(Primitive::Boolean(_))
|
| UntaggedValue::Primitive(Primitive::Boolean(_))
|
||||||
| UntaggedValue::Primitive(Primitive::Decimal(_))
|
| UntaggedValue::Primitive(Primitive::Decimal(_))
|
||||||
| UntaggedValue::Primitive(Primitive::Path(_))
|
| UntaggedValue::Primitive(Primitive::Path(_))
|
||||||
|
|
|
@ -62,7 +62,7 @@ impl WholeStreamCommand for ToJSON {
|
||||||
pub fn value_to_json_value(v: &Value) -> Result<serde_json::Value, ShellError> {
|
pub fn value_to_json_value(v: &Value) -> Result<serde_json::Value, ShellError> {
|
||||||
Ok(match &v.value {
|
Ok(match &v.value {
|
||||||
UntaggedValue::Primitive(Primitive::Boolean(b)) => serde_json::Value::Bool(*b),
|
UntaggedValue::Primitive(Primitive::Boolean(b)) => serde_json::Value::Bool(*b),
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(b)) => serde_json::Value::Number(
|
UntaggedValue::Primitive(Primitive::Filesize(b)) => serde_json::Value::Number(
|
||||||
serde_json::Number::from(b.to_u64().expect("What about really big numbers")),
|
serde_json::Number::from(b.to_u64().expect("What about really big numbers")),
|
||||||
),
|
),
|
||||||
UntaggedValue::Primitive(Primitive::Duration(i)) => {
|
UntaggedValue::Primitive(Primitive::Duration(i)) => {
|
||||||
|
|
|
@ -93,7 +93,7 @@ fn nu_value_to_sqlite_string(v: Value) -> String {
|
||||||
Primitive::Int(i) => format!("{}", i),
|
Primitive::Int(i) => format!("{}", i),
|
||||||
Primitive::Duration(i) => format!("{}", i),
|
Primitive::Duration(i) => format!("{}", i),
|
||||||
Primitive::Decimal(f) => format!("{}", f),
|
Primitive::Decimal(f) => format!("{}", f),
|
||||||
Primitive::Bytes(u) => format!("{}", u),
|
Primitive::Filesize(u) => format!("{}", u),
|
||||||
Primitive::Pattern(s) => format!("'{}'", s.replace("'", "''")),
|
Primitive::Pattern(s) => format!("'{}'", s.replace("'", "''")),
|
||||||
Primitive::String(s) => format!("'{}'", s.replace("'", "''")),
|
Primitive::String(s) => format!("'{}'", s.replace("'", "''")),
|
||||||
Primitive::Line(s) => format!("'{}'", s.replace("'", "''")),
|
Primitive::Line(s) => format!("'{}'", s.replace("'", "''")),
|
||||||
|
|
|
@ -44,7 +44,7 @@ impl WholeStreamCommand for ToTOML {
|
||||||
fn helper(v: &Value) -> Result<toml::Value, ShellError> {
|
fn helper(v: &Value) -> Result<toml::Value, ShellError> {
|
||||||
Ok(match &v.value {
|
Ok(match &v.value {
|
||||||
UntaggedValue::Primitive(Primitive::Boolean(b)) => toml::Value::Boolean(*b),
|
UntaggedValue::Primitive(Primitive::Boolean(b)) => toml::Value::Boolean(*b),
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(b)) => toml::Value::Integer(*b as i64),
|
UntaggedValue::Primitive(Primitive::Filesize(b)) => toml::Value::Integer(*b as i64),
|
||||||
UntaggedValue::Primitive(Primitive::Duration(i)) => toml::Value::String(i.to_string()),
|
UntaggedValue::Primitive(Primitive::Duration(i)) => toml::Value::String(i.to_string()),
|
||||||
UntaggedValue::Primitive(Primitive::Date(d)) => toml::Value::String(d.to_string()),
|
UntaggedValue::Primitive(Primitive::Date(d)) => toml::Value::String(d.to_string()),
|
||||||
UntaggedValue::Primitive(Primitive::EndOfStream) => {
|
UntaggedValue::Primitive(Primitive::EndOfStream) => {
|
||||||
|
|
|
@ -31,7 +31,7 @@ impl WholeStreamCommand for ToYAML {
|
||||||
pub fn value_to_yaml_value(v: &Value) -> Result<serde_yaml::Value, ShellError> {
|
pub fn value_to_yaml_value(v: &Value) -> Result<serde_yaml::Value, ShellError> {
|
||||||
Ok(match &v.value {
|
Ok(match &v.value {
|
||||||
UntaggedValue::Primitive(Primitive::Boolean(b)) => serde_yaml::Value::Bool(*b),
|
UntaggedValue::Primitive(Primitive::Boolean(b)) => serde_yaml::Value::Bool(*b),
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(b)) => {
|
UntaggedValue::Primitive(Primitive::Filesize(b)) => {
|
||||||
serde_yaml::Value::Number(serde_yaml::Number::from(b.to_f64().ok_or_else(|| {
|
serde_yaml::Value::Number(serde_yaml::Number::from(b.to_f64().ok_or_else(|| {
|
||||||
ShellError::labeled_error(
|
ShellError::labeled_error(
|
||||||
"Could not convert to bytes",
|
"Could not convert to bytes",
|
||||||
|
|
|
@ -43,7 +43,7 @@ fn trim_primitive(p: &mut Primitive) {
|
||||||
Primitive::Nothing
|
Primitive::Nothing
|
||||||
| Primitive::Int(_)
|
| Primitive::Int(_)
|
||||||
| Primitive::Decimal(_)
|
| Primitive::Decimal(_)
|
||||||
| Primitive::Bytes(_)
|
| Primitive::Filesize(_)
|
||||||
| Primitive::ColumnPath(_)
|
| Primitive::ColumnPath(_)
|
||||||
| Primitive::Pattern(_)
|
| Primitive::Pattern(_)
|
||||||
| Primitive::Boolean(_)
|
| Primitive::Boolean(_)
|
||||||
|
|
|
@ -138,19 +138,19 @@ fn coerce_compare_primitive(
|
||||||
(Int(left), Decimal(right)) => {
|
(Int(left), Decimal(right)) => {
|
||||||
CompareValues::Decimals(BigDecimal::zero() + left, right.clone())
|
CompareValues::Decimals(BigDecimal::zero() + left, right.clone())
|
||||||
}
|
}
|
||||||
(Int(left), Bytes(right)) => CompareValues::Ints(left.clone(), BigInt::from(*right)),
|
(Int(left), Filesize(right)) => CompareValues::Ints(left.clone(), BigInt::from(*right)),
|
||||||
(Decimal(left), Decimal(right)) => CompareValues::Decimals(left.clone(), right.clone()),
|
(Decimal(left), Decimal(right)) => CompareValues::Decimals(left.clone(), right.clone()),
|
||||||
(Decimal(left), Int(right)) => {
|
(Decimal(left), Int(right)) => {
|
||||||
CompareValues::Decimals(left.clone(), BigDecimal::zero() + right)
|
CompareValues::Decimals(left.clone(), BigDecimal::zero() + right)
|
||||||
}
|
}
|
||||||
(Decimal(left), Bytes(right)) => {
|
(Decimal(left), Filesize(right)) => {
|
||||||
CompareValues::Decimals(left.clone(), BigDecimal::from(*right))
|
CompareValues::Decimals(left.clone(), BigDecimal::from(*right))
|
||||||
}
|
}
|
||||||
(Bytes(left), Bytes(right)) => {
|
(Filesize(left), Filesize(right)) => {
|
||||||
CompareValues::Ints(BigInt::from(*left), BigInt::from(*right))
|
CompareValues::Ints(BigInt::from(*left), BigInt::from(*right))
|
||||||
}
|
}
|
||||||
(Bytes(left), Int(right)) => CompareValues::Ints(BigInt::from(*left), right.clone()),
|
(Filesize(left), Int(right)) => CompareValues::Ints(BigInt::from(*left), right.clone()),
|
||||||
(Bytes(left), Decimal(right)) => {
|
(Filesize(left), Decimal(right)) => {
|
||||||
CompareValues::Decimals(BigDecimal::from(*left), right.clone())
|
CompareValues::Decimals(BigDecimal::from(*left), right.clone())
|
||||||
}
|
}
|
||||||
(Nothing, Nothing) => CompareValues::Booleans(true, true),
|
(Nothing, Nothing) => CompareValues::Booleans(true, true),
|
||||||
|
|
|
@ -64,7 +64,7 @@ impl InlineShape {
|
||||||
}))
|
}))
|
||||||
}
|
}
|
||||||
Primitive::Decimal(decimal) => InlineShape::Decimal(decimal.clone()),
|
Primitive::Decimal(decimal) => InlineShape::Decimal(decimal.clone()),
|
||||||
Primitive::Bytes(bytesize) => InlineShape::Bytesize(*bytesize),
|
Primitive::Filesize(bytesize) => InlineShape::Bytesize(*bytesize),
|
||||||
Primitive::String(string) => InlineShape::String(string.clone()),
|
Primitive::String(string) => InlineShape::String(string.clone()),
|
||||||
Primitive::Line(string) => InlineShape::Line(string.clone()),
|
Primitive::Line(string) => InlineShape::Line(string.clone()),
|
||||||
Primitive::ColumnPath(path) => InlineShape::ColumnPath(path.clone()),
|
Primitive::ColumnPath(path) => InlineShape::ColumnPath(path.clone()),
|
||||||
|
|
|
@ -168,12 +168,12 @@ pub(crate) fn dir_entry_dict(
|
||||||
md.len()
|
md.len()
|
||||||
};
|
};
|
||||||
|
|
||||||
size_untagged_value = UntaggedValue::bytes(dir_size);
|
size_untagged_value = UntaggedValue::filesize(dir_size);
|
||||||
} else if md.is_file() {
|
} else if md.is_file() {
|
||||||
size_untagged_value = UntaggedValue::bytes(md.len());
|
size_untagged_value = UntaggedValue::filesize(md.len());
|
||||||
} else if md.file_type().is_symlink() {
|
} else if md.file_type().is_symlink() {
|
||||||
if let Ok(symlink_md) = filename.symlink_metadata() {
|
if let Ok(symlink_md) = filename.symlink_metadata() {
|
||||||
size_untagged_value = UntaggedValue::bytes(symlink_md.len() as u64);
|
size_untagged_value = UntaggedValue::filesize(symlink_md.len() as u64);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,9 @@ pub fn number(number: impl Into<Number>) -> Primitive {
|
||||||
|
|
||||||
pub fn style_primitive(primitive: &Primitive) -> TextStyle {
|
pub fn style_primitive(primitive: &Primitive) -> TextStyle {
|
||||||
match primitive {
|
match primitive {
|
||||||
Primitive::Int(_) | Primitive::Bytes(_) | Primitive::Decimal(_) => TextStyle::basic_right(),
|
Primitive::Int(_) | Primitive::Filesize(_) | Primitive::Decimal(_) => {
|
||||||
|
TextStyle::basic_right()
|
||||||
|
}
|
||||||
_ => TextStyle::basic(),
|
_ => TextStyle::basic(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,13 +47,13 @@ pub fn compute_values(
|
||||||
) -> Result<UntaggedValue, (&'static str, &'static str)> {
|
) -> Result<UntaggedValue, (&'static str, &'static str)> {
|
||||||
match (left, right) {
|
match (left, right) {
|
||||||
(UntaggedValue::Primitive(lhs), UntaggedValue::Primitive(rhs)) => match (lhs, rhs) {
|
(UntaggedValue::Primitive(lhs), UntaggedValue::Primitive(rhs)) => match (lhs, rhs) {
|
||||||
(Primitive::Bytes(x), Primitive::Bytes(y)) => {
|
(Primitive::Filesize(x), Primitive::Filesize(y)) => {
|
||||||
let result = match operator {
|
let result = match operator {
|
||||||
Operator::Plus => Ok(x + y),
|
Operator::Plus => Ok(x + y),
|
||||||
Operator::Minus => Ok(x - y),
|
Operator::Minus => Ok(x - y),
|
||||||
_ => Err((left.type_name(), right.type_name())),
|
_ => Err((left.type_name(), right.type_name())),
|
||||||
}?;
|
}?;
|
||||||
Ok(UntaggedValue::Primitive(Primitive::Bytes(result)))
|
Ok(UntaggedValue::Primitive(Primitive::Filesize(result)))
|
||||||
}
|
}
|
||||||
(Primitive::Int(x), Primitive::Int(y)) => match operator {
|
(Primitive::Int(x), Primitive::Int(y)) => match operator {
|
||||||
Operator::Plus => Ok(UntaggedValue::Primitive(Primitive::Int(x + y))),
|
Operator::Plus => Ok(UntaggedValue::Primitive(Primitive::Int(x + y))),
|
||||||
|
|
|
@ -497,13 +497,13 @@ impl Unit {
|
||||||
let size = size.clone();
|
let size = size.clone();
|
||||||
|
|
||||||
match self {
|
match self {
|
||||||
Unit::Byte => bytes(convert_number_to_u64(&size)),
|
Unit::Byte => filesize(convert_number_to_u64(&size)),
|
||||||
Unit::Kilobyte => bytes(convert_number_to_u64(&size) * 1024),
|
Unit::Kilobyte => filesize(convert_number_to_u64(&size) * 1024),
|
||||||
Unit::Megabyte => bytes(convert_number_to_u64(&size) * 1024 * 1024),
|
Unit::Megabyte => filesize(convert_number_to_u64(&size) * 1024 * 1024),
|
||||||
Unit::Gigabyte => bytes(convert_number_to_u64(&size) * 1024 * 1024 * 1024),
|
Unit::Gigabyte => filesize(convert_number_to_u64(&size) * 1024 * 1024 * 1024),
|
||||||
Unit::Terabyte => bytes(convert_number_to_u64(&size) * 1024 * 1024 * 1024 * 1024),
|
Unit::Terabyte => filesize(convert_number_to_u64(&size) * 1024 * 1024 * 1024 * 1024),
|
||||||
Unit::Petabyte => {
|
Unit::Petabyte => {
|
||||||
bytes(convert_number_to_u64(&size) * 1024 * 1024 * 1024 * 1024 * 1024)
|
filesize(convert_number_to_u64(&size) * 1024 * 1024 * 1024 * 1024 * 1024)
|
||||||
}
|
}
|
||||||
Unit::Nanosecond => duration(size.to_bigint().expect("Conversion should never fail.")),
|
Unit::Nanosecond => duration(size.to_bigint().expect("Conversion should never fail.")),
|
||||||
Unit::Microsecond => {
|
Unit::Microsecond => {
|
||||||
|
@ -571,8 +571,8 @@ impl Unit {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn bytes(size: u64) -> UntaggedValue {
|
pub fn filesize(size_in_bytes: u64) -> UntaggedValue {
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(size))
|
UntaggedValue::Primitive(Primitive::Filesize(size_in_bytes))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn duration(nanos: BigInt) -> UntaggedValue {
|
pub fn duration(nanos: BigInt) -> UntaggedValue {
|
||||||
|
|
|
@ -34,7 +34,7 @@ pub enum Type {
|
||||||
/// A decimal (floating point) value
|
/// A decimal (floating point) value
|
||||||
Decimal,
|
Decimal,
|
||||||
/// A filesize in bytes
|
/// A filesize in bytes
|
||||||
Bytesize,
|
Filesize,
|
||||||
/// A string of text
|
/// A string of text
|
||||||
String,
|
String,
|
||||||
/// A line of text (a string with trailing line ending)
|
/// A line of text (a string with trailing line ending)
|
||||||
|
@ -138,7 +138,7 @@ impl Type {
|
||||||
Type::Range(Box::new(range))
|
Type::Range(Box::new(range))
|
||||||
}
|
}
|
||||||
Primitive::Decimal(_) => Type::Decimal,
|
Primitive::Decimal(_) => Type::Decimal,
|
||||||
Primitive::Bytes(_) => Type::Bytesize,
|
Primitive::Filesize(_) => Type::Filesize,
|
||||||
Primitive::String(_) => Type::String,
|
Primitive::String(_) => Type::String,
|
||||||
Primitive::Line(_) => Type::Line,
|
Primitive::Line(_) => Type::Line,
|
||||||
Primitive::ColumnPath(_) => Type::ColumnPath,
|
Primitive::ColumnPath(_) => Type::ColumnPath,
|
||||||
|
@ -220,7 +220,7 @@ impl PrettyDebug for Type {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
Type::Decimal => ty("decimal"),
|
Type::Decimal => ty("decimal"),
|
||||||
Type::Bytesize => ty("bytesize"),
|
Type::Filesize => ty("filesize"),
|
||||||
Type::String => ty("string"),
|
Type::String => ty("string"),
|
||||||
Type::Line => ty("line"),
|
Type::Line => ty("line"),
|
||||||
Type::ColumnPath => ty("column-path"),
|
Type::ColumnPath => ty("column-path"),
|
||||||
|
|
|
@ -183,9 +183,9 @@ impl UntaggedValue {
|
||||||
UntaggedValue::Primitive(Primitive::Path(s.into()))
|
UntaggedValue::Primitive(Primitive::Path(s.into()))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Helper for creating bytesize values
|
/// Helper for creating filesize values
|
||||||
pub fn bytes(s: impl Into<u64>) -> UntaggedValue {
|
pub fn filesize(s: impl Into<u64>) -> UntaggedValue {
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(s.into()))
|
UntaggedValue::Primitive(Primitive::Filesize(s.into()))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Helper for creating decimal values
|
/// Helper for creating decimal values
|
||||||
|
@ -282,7 +282,7 @@ impl Value {
|
||||||
UntaggedValue::Primitive(Primitive::Boolean(x)) => format!("{}", x),
|
UntaggedValue::Primitive(Primitive::Boolean(x)) => format!("{}", x),
|
||||||
UntaggedValue::Primitive(Primitive::Decimal(x)) => format!("{}", x),
|
UntaggedValue::Primitive(Primitive::Decimal(x)) => format!("{}", x),
|
||||||
UntaggedValue::Primitive(Primitive::Int(x)) => format!("{}", x),
|
UntaggedValue::Primitive(Primitive::Int(x)) => format!("{}", x),
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(x)) => format!("{}", x),
|
UntaggedValue::Primitive(Primitive::Filesize(x)) => format!("{}", x),
|
||||||
UntaggedValue::Primitive(Primitive::Path(x)) => format!("{}", x.display()),
|
UntaggedValue::Primitive(Primitive::Path(x)) => format!("{}", x.display()),
|
||||||
UntaggedValue::Primitive(Primitive::ColumnPath(path)) => {
|
UntaggedValue::Primitive(Primitive::ColumnPath(path)) => {
|
||||||
let joined = path
|
let joined = path
|
||||||
|
|
|
@ -33,7 +33,7 @@ impl PrettyType for Primitive {
|
||||||
Primitive::Int(_) => ty("integer"),
|
Primitive::Int(_) => ty("integer"),
|
||||||
Primitive::Range(_) => ty("range"),
|
Primitive::Range(_) => ty("range"),
|
||||||
Primitive::Decimal(_) => ty("decimal"),
|
Primitive::Decimal(_) => ty("decimal"),
|
||||||
Primitive::Bytes(_) => ty("bytesize"),
|
Primitive::Filesize(_) => ty("filesize"),
|
||||||
Primitive::String(_) => ty("string"),
|
Primitive::String(_) => ty("string"),
|
||||||
Primitive::Line(_) => ty("line"),
|
Primitive::Line(_) => ty("line"),
|
||||||
Primitive::ColumnPath(_) => ty("column-path"),
|
Primitive::ColumnPath(_) => ty("column-path"),
|
||||||
|
@ -71,7 +71,7 @@ impl PrettyDebug for Primitive {
|
||||||
.group(),
|
.group(),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
Primitive::Bytes(bytes) => primitive_doc(bytes, "bytesize"),
|
Primitive::Filesize(bytes) => primitive_doc(bytes, "filesize"),
|
||||||
Primitive::String(string) => prim(string),
|
Primitive::String(string) => prim(string),
|
||||||
Primitive::Line(string) => prim(string),
|
Primitive::Line(string) => prim(string),
|
||||||
Primitive::ColumnPath(path) => path.pretty(),
|
Primitive::ColumnPath(path) => path.pretty(),
|
||||||
|
|
|
@ -31,7 +31,7 @@ pub enum Primitive {
|
||||||
#[serde(with = "serde_bigdecimal")]
|
#[serde(with = "serde_bigdecimal")]
|
||||||
Decimal(BigDecimal),
|
Decimal(BigDecimal),
|
||||||
/// A count in the number of bytes, used as a filesize
|
/// A count in the number of bytes, used as a filesize
|
||||||
Bytes(u64),
|
Filesize(u64),
|
||||||
/// A string value
|
/// A string value
|
||||||
String(String),
|
String(String),
|
||||||
/// A string value with an implied carriage return (or cr/lf) ending
|
/// A string value with an implied carriage return (or cr/lf) ending
|
||||||
|
@ -143,7 +143,7 @@ impl num_traits::Zero for Primitive {
|
||||||
match self {
|
match self {
|
||||||
Primitive::Int(int) => int.is_zero(),
|
Primitive::Int(int) => int.is_zero(),
|
||||||
Primitive::Decimal(decimal) => decimal.is_zero(),
|
Primitive::Decimal(decimal) => decimal.is_zero(),
|
||||||
Primitive::Bytes(size) => size.is_zero(),
|
Primitive::Filesize(num_bytes) => num_bytes.is_zero(),
|
||||||
_ => false,
|
_ => false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -164,25 +164,25 @@ impl std::ops::Add for Primitive {
|
||||||
(Primitive::Decimal(left), Primitive::Int(right)) => {
|
(Primitive::Decimal(left), Primitive::Int(right)) => {
|
||||||
Primitive::Decimal(left + BigDecimal::from(right))
|
Primitive::Decimal(left + BigDecimal::from(right))
|
||||||
}
|
}
|
||||||
(Primitive::Bytes(left), right) => match right {
|
(Primitive::Filesize(left), right) => match right {
|
||||||
Primitive::Bytes(right) => Primitive::Bytes(left + right),
|
Primitive::Filesize(right) => Primitive::Filesize(left + right),
|
||||||
Primitive::Int(right) => {
|
Primitive::Int(right) => {
|
||||||
Primitive::Bytes(left + right.to_u64().unwrap_or_else(|| 0 as u64))
|
Primitive::Filesize(left + right.to_u64().unwrap_or_else(|| 0 as u64))
|
||||||
}
|
}
|
||||||
Primitive::Decimal(right) => {
|
Primitive::Decimal(right) => {
|
||||||
Primitive::Bytes(left + right.to_u64().unwrap_or_else(|| 0 as u64))
|
Primitive::Filesize(left + right.to_u64().unwrap_or_else(|| 0 as u64))
|
||||||
}
|
}
|
||||||
_ => Primitive::Bytes(left),
|
_ => Primitive::Filesize(left),
|
||||||
},
|
},
|
||||||
(left, Primitive::Bytes(right)) => match left {
|
(left, Primitive::Filesize(right)) => match left {
|
||||||
Primitive::Bytes(left) => Primitive::Bytes(left + right),
|
Primitive::Filesize(left) => Primitive::Filesize(left + right),
|
||||||
Primitive::Int(left) => {
|
Primitive::Int(left) => {
|
||||||
Primitive::Bytes(left.to_u64().unwrap_or_else(|| 0 as u64) + right)
|
Primitive::Filesize(left.to_u64().unwrap_or_else(|| 0 as u64) + right)
|
||||||
}
|
}
|
||||||
Primitive::Decimal(left) => {
|
Primitive::Decimal(left) => {
|
||||||
Primitive::Bytes(left.to_u64().unwrap_or_else(|| 0 as u64) + right)
|
Primitive::Filesize(left.to_u64().unwrap_or_else(|| 0 as u64) + right)
|
||||||
}
|
}
|
||||||
_ => Primitive::Bytes(right),
|
_ => Primitive::Filesize(right),
|
||||||
},
|
},
|
||||||
_ => Primitive::zero(),
|
_ => Primitive::zero(),
|
||||||
}
|
}
|
||||||
|
@ -270,7 +270,7 @@ impl ShellTypeName for Primitive {
|
||||||
Primitive::Int(_) => "integer",
|
Primitive::Int(_) => "integer",
|
||||||
Primitive::Range(_) => "range",
|
Primitive::Range(_) => "range",
|
||||||
Primitive::Decimal(_) => "decimal",
|
Primitive::Decimal(_) => "decimal",
|
||||||
Primitive::Bytes(_) => "bytes",
|
Primitive::Filesize(_) => "filesize(in bytes)",
|
||||||
Primitive::String(_) => "string",
|
Primitive::String(_) => "string",
|
||||||
Primitive::Line(_) => "line",
|
Primitive::Line(_) => "line",
|
||||||
Primitive::ColumnPath(_) => "column path",
|
Primitive::ColumnPath(_) => "column path",
|
||||||
|
@ -293,8 +293,8 @@ pub fn format_primitive(primitive: &Primitive, field_name: Option<&String>) -> S
|
||||||
Primitive::BeginningOfStream => String::new(),
|
Primitive::BeginningOfStream => String::new(),
|
||||||
Primitive::EndOfStream => String::new(),
|
Primitive::EndOfStream => String::new(),
|
||||||
Primitive::Path(p) => format!("{}", p.display()),
|
Primitive::Path(p) => format!("{}", p.display()),
|
||||||
Primitive::Bytes(b) => {
|
Primitive::Filesize(num_bytes) => {
|
||||||
let byte = byte_unit::Byte::from_bytes(*b as u128);
|
let byte = byte_unit::Byte::from_bytes(*num_bytes as u128);
|
||||||
|
|
||||||
if byte.get_bytes() == 0u128 {
|
if byte.get_bytes() == 0u128 {
|
||||||
return "—".to_string();
|
return "—".to_string();
|
||||||
|
|
|
@ -563,7 +563,7 @@ pub fn as_string(value: &Value) -> Result<String, ShellError> {
|
||||||
UntaggedValue::Primitive(Primitive::Boolean(x)) => Ok(format!("{}", x)),
|
UntaggedValue::Primitive(Primitive::Boolean(x)) => Ok(format!("{}", x)),
|
||||||
UntaggedValue::Primitive(Primitive::Decimal(x)) => Ok(format!("{}", x)),
|
UntaggedValue::Primitive(Primitive::Decimal(x)) => Ok(format!("{}", x)),
|
||||||
UntaggedValue::Primitive(Primitive::Int(x)) => Ok(format!("{}", x)),
|
UntaggedValue::Primitive(Primitive::Int(x)) => Ok(format!("{}", x)),
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(x)) => Ok(format!("{}", x)),
|
UntaggedValue::Primitive(Primitive::Filesize(x)) => Ok(format!("{}", x)),
|
||||||
UntaggedValue::Primitive(Primitive::Path(x)) => Ok(format!("{}", x.display())),
|
UntaggedValue::Primitive(Primitive::Path(x)) => Ok(format!("{}", x.display())),
|
||||||
UntaggedValue::Primitive(Primitive::ColumnPath(path)) => {
|
UntaggedValue::Primitive(Primitive::ColumnPath(path)) => {
|
||||||
let joined = path
|
let joined = path
|
||||||
|
|
|
@ -78,8 +78,8 @@ impl Inc {
|
||||||
UntaggedValue::Primitive(Primitive::Int(i)) => {
|
UntaggedValue::Primitive(Primitive::Int(i)) => {
|
||||||
Ok(UntaggedValue::int(i + 1).into_value(value.tag()))
|
Ok(UntaggedValue::int(i + 1).into_value(value.tag()))
|
||||||
}
|
}
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(b)) => {
|
UntaggedValue::Primitive(Primitive::Filesize(b)) => {
|
||||||
Ok(UntaggedValue::bytes(b + 1 as u64).into_value(value.tag()))
|
Ok(UntaggedValue::filesize(b + 1 as u64).into_value(value.tag()))
|
||||||
}
|
}
|
||||||
UntaggedValue::Primitive(Primitive::String(ref s)) => {
|
UntaggedValue::Primitive(Primitive::String(ref s)) => {
|
||||||
Ok(self.apply(&s)?.into_value(value.tag()))
|
Ok(self.apply(&s)?.into_value(value.tag()))
|
||||||
|
|
|
@ -347,7 +347,7 @@ pub async fn post(
|
||||||
pub fn value_to_json_value(v: &Value) -> Result<serde_json::Value, ShellError> {
|
pub fn value_to_json_value(v: &Value) -> Result<serde_json::Value, ShellError> {
|
||||||
Ok(match &v.value {
|
Ok(match &v.value {
|
||||||
UntaggedValue::Primitive(Primitive::Boolean(b)) => serde_json::Value::Bool(*b),
|
UntaggedValue::Primitive(Primitive::Boolean(b)) => serde_json::Value::Bool(*b),
|
||||||
UntaggedValue::Primitive(Primitive::Bytes(b)) => serde_json::Value::Number(
|
UntaggedValue::Primitive(Primitive::Filesize(b)) => serde_json::Value::Number(
|
||||||
serde_json::Number::from(b.to_u64().expect("What about really big numbers")),
|
serde_json::Number::from(b.to_u64().expect("What about really big numbers")),
|
||||||
),
|
),
|
||||||
UntaggedValue::Primitive(Primitive::Duration(i)) => {
|
UntaggedValue::Primitive(Primitive::Duration(i)) => {
|
||||||
|
|
|
@ -61,11 +61,11 @@ pub async fn ps(tag: Tag, full: bool) -> Result<Vec<Value>, ShellError> {
|
||||||
dict.insert_untagged("cpu", UntaggedValue::decimal(usage.get::<ratio::percent>()));
|
dict.insert_untagged("cpu", UntaggedValue::decimal(usage.get::<ratio::percent>()));
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"mem",
|
"mem",
|
||||||
UntaggedValue::bytes(memory.rss().get::<information::byte>()),
|
UntaggedValue::filesize(memory.rss().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"virtual",
|
"virtual",
|
||||||
UntaggedValue::bytes(memory.vms().get::<information::byte>()),
|
UntaggedValue::filesize(memory.vms().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
if full {
|
if full {
|
||||||
if let Ok(parent_pid) = process.parent_pid().await {
|
if let Ok(parent_pid) = process.parent_pid().await {
|
||||||
|
|
|
@ -57,22 +57,22 @@ async fn mem(tag: Tag) -> Value {
|
||||||
if let Ok(memory) = memory_result {
|
if let Ok(memory) = memory_result {
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"total",
|
"total",
|
||||||
UntaggedValue::bytes(memory.total().get::<information::byte>()),
|
UntaggedValue::filesize(memory.total().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"free",
|
"free",
|
||||||
UntaggedValue::bytes(memory.free().get::<information::byte>()),
|
UntaggedValue::filesize(memory.free().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Ok(swap) = swap_result {
|
if let Ok(swap) = swap_result {
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"swap total",
|
"swap total",
|
||||||
UntaggedValue::bytes(swap.total().get::<information::byte>()),
|
UntaggedValue::filesize(swap.total().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"swap free",
|
"swap free",
|
||||||
UntaggedValue::bytes(swap.free().get::<information::byte>()),
|
UntaggedValue::filesize(swap.free().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -160,15 +160,15 @@ async fn disks(tag: Tag) -> Result<Option<UntaggedValue>, ShellError> {
|
||||||
if let Ok(usage) = disk::usage(part.mount_point().to_path_buf()).await {
|
if let Ok(usage) = disk::usage(part.mount_point().to_path_buf()).await {
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"total",
|
"total",
|
||||||
UntaggedValue::bytes(usage.total().get::<information::byte>()),
|
UntaggedValue::filesize(usage.total().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"used",
|
"used",
|
||||||
UntaggedValue::bytes(usage.used().get::<information::byte>()),
|
UntaggedValue::filesize(usage.used().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
dict.insert_untagged(
|
dict.insert_untagged(
|
||||||
"free",
|
"free",
|
||||||
UntaggedValue::bytes(usage.free().get::<information::byte>()),
|
UntaggedValue::filesize(usage.free().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -295,11 +295,11 @@ async fn net(tag: Tag) -> Result<Option<UntaggedValue>, ShellError> {
|
||||||
network_idx.insert_untagged("name", UntaggedValue::string(nic.interface()));
|
network_idx.insert_untagged("name", UntaggedValue::string(nic.interface()));
|
||||||
network_idx.insert_untagged(
|
network_idx.insert_untagged(
|
||||||
"sent",
|
"sent",
|
||||||
UntaggedValue::bytes(nic.bytes_sent().get::<information::byte>()),
|
UntaggedValue::filesize(nic.bytes_sent().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
network_idx.insert_untagged(
|
network_idx.insert_untagged(
|
||||||
"recv",
|
"recv",
|
||||||
UntaggedValue::bytes(nic.bytes_recv().get::<information::byte>()),
|
UntaggedValue::filesize(nic.bytes_recv().get::<information::byte>()),
|
||||||
);
|
);
|
||||||
output.push(network_idx.into_value());
|
output.push(network_idx.into_value());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue