2014-05-04 21:33:14 +01:00
|
|
|
pub enum Column {
|
|
|
|
Permissions,
|
|
|
|
FileName,
|
|
|
|
FileSize(bool),
|
2014-05-27 19:05:15 +01:00
|
|
|
User(u64),
|
2014-05-05 11:29:50 +01:00
|
|
|
Group,
|
2014-05-04 21:33:14 +01:00
|
|
|
}
|
2014-06-03 21:14:35 +01:00
|
|
|
|
|
|
|
// Each column can pick its own alignment. Usually, numbers are
|
|
|
|
// right-aligned, and text is left-aligned.
|
|
|
|
|
|
|
|
pub enum Alignment {
|
|
|
|
Left, Right,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Column {
|
|
|
|
pub fn alignment(&self) -> Alignment {
|
|
|
|
match *self {
|
|
|
|
FileSize(_) => Right,
|
|
|
|
_ => Left,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// An Alignment is used to pad a string to a certain length, letting
|
|
|
|
// it pick which end it puts the text on. The length of the string is
|
|
|
|
// passed in specifically because it needs to be the *unformatted*
|
|
|
|
// length, rather than just the number of characters.
|
|
|
|
|
|
|
|
impl Alignment {
|
|
|
|
pub fn pad_string(&self, string: &String, string_length: uint, width: uint) -> String {
|
|
|
|
let mut str = String::new();
|
|
|
|
match *self {
|
|
|
|
Left => {
|
|
|
|
str.push_str(string.as_slice());
|
|
|
|
for _ in range(string_length, width) {
|
|
|
|
str.push_char(' ');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Right => {
|
|
|
|
for _ in range(string_length, width) {
|
|
|
|
str.push_char(' ');
|
|
|
|
}
|
|
|
|
str.push_str(string.as_slice());
|
|
|
|
},
|
|
|
|
}
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|