Rename 'bytes' to 'filesize' (#2153)

This commit is contained in:
Jonathan Turner 2020-07-10 19:17:37 -07:00 committed by GitHub
parent 1bb6a2d9ed
commit 0bc2e29f99
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
25 changed files with 78 additions and 76 deletions

View file

@ -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);

View file

@ -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",

View file

@ -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",

View file

@ -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?"),

View file

@ -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(_))

View file

@ -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)) => {

View file

@ -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("'", "''")),

View file

@ -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) => {

View file

@ -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",

View file

@ -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(_)

View file

@ -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),

View file

@ -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()),

View file

@ -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);
} }
} }

View file

@ -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(),
} }
} }

View file

@ -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))),

View file

@ -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 {

View file

@ -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"),

View file

@ -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

View file

@ -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(),

View file

@ -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();

View file

@ -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

View file

@ -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()))

View file

@ -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)) => {

View file

@ -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 {

View file

@ -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());
} }