aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMatthias Krüger <matthias.krueger@famsik.de>2018-09-18 01:34:56 +0200
committerChristian Duerr <chrisduerr@users.noreply.github.com>2018-09-17 23:34:56 +0000
commit63a40df5203178bbea1ff1a6988e6d30b6f992f4 (patch)
treecdfef3dbeaf3fc53844574c58082c08cf4e7a202 /src
parent55e675a3d89922d9d7966cd7bccf0da9d9eff654 (diff)
downloadalacritty-63a40df5203178bbea1ff1a6988e6d30b6f992f4.tar.gz
alacritty-63a40df5203178bbea1ff1a6988e6d30b6f992f4.zip
Fix style issues
Diffstat (limited to 'src')
-rw-r--r--src/grid/row.rs19
-rw-r--r--src/grid/storage.rs4
-rw-r--r--src/locale.rs2
-rw-r--r--src/term/mod.rs2
4 files changed, 22 insertions, 5 deletions
diff --git a/src/grid/row.rs b/src/grid/row.rs
index 69a4f2b2..7c12bf99 100644
--- a/src/grid/row.rs
+++ b/src/grid/row.rs
@@ -15,7 +15,7 @@
//! Defines the Row type which makes up lines in the grid
use std::ops::{Index, IndexMut};
-use std::ops::{Range, RangeTo, RangeFrom, RangeFull};
+use std::ops::{Range, RangeTo, RangeFrom, RangeFull, RangeToInclusive};
use std::cmp::{max, min};
use std::slice;
@@ -200,3 +200,20 @@ impl<T> IndexMut<RangeFull> for Row<T> {
&mut self.inner[..]
}
}
+
+impl<T> Index<RangeToInclusive<Column>> for Row<T> {
+ type Output = [T];
+
+ #[inline]
+ fn index(&self, index: RangeToInclusive<Column>) -> &[T] {
+ &self.inner[..=(index.end.0)]
+ }
+}
+
+impl<T> IndexMut<RangeToInclusive<Column>> for Row<T> {
+ #[inline]
+ fn index_mut(&mut self, index: RangeToInclusive<Column>) -> &mut [T] {
+ self.occ = max(self.occ, *index.end);
+ &mut self.inner[..=(index.end.0)]
+ }
+}
diff --git a/src/grid/storage.rs b/src/grid/storage.rs
index ad94cf2b..af2bd35c 100644
--- a/src/grid/storage.rs
+++ b/src/grid/storage.rs
@@ -232,8 +232,8 @@ impl<T> Storage<T> {
// Cast to a qword array to opt out of copy restrictions and avoid
// drop hazards. Byte array is no good here since for whatever
// reason LLVM won't optimized it.
- let a_ptr = self.inner.as_mut_ptr().offset(a as isize) as *mut u64;
- let b_ptr = self.inner.as_mut_ptr().offset(b as isize) as *mut u64;
+ let a_ptr = self.inner.as_mut_ptr().add(a) as *mut u64;
+ let b_ptr = self.inner.as_mut_ptr().add(b) as *mut u64;
// Copy 1 qword at a time
//
diff --git a/src/locale.rs b/src/locale.rs
index bea68cad..833de71e 100644
--- a/src/locale.rs
+++ b/src/locale.rs
@@ -67,7 +67,7 @@ pub fn set_locale_environment() {
// try setting `locale_id`
let modified = setlocale(LC_CTYPE, locale_ptr);
let result = if modified.is_null() {
- String::from("")
+ String::new()
} else {
locale_id
};
diff --git a/src/term/mod.rs b/src/term/mod.rs
index 04d110af..f4ebf1c9 100644
--- a/src/term/mod.rs
+++ b/src/term/mod.rs
@@ -1725,7 +1725,7 @@ impl ansi::Handler for Term {
},
ansi::LineClearMode::Left => {
let row = &mut self.grid[self.cursor.point.line];
- for cell in &mut row[..(col + 1)] {
+ for cell in &mut row[..=col] {
cell.reset(&template);
}
},