aboutsummaryrefslogtreecommitdiff
path: root/src/renderer
diff options
context:
space:
mode:
authorJoe Wilm <joe@jwilm.com>2016-12-04 13:13:44 -0800
committerJoe Wilm <joe@jwilm.com>2016-12-11 20:23:41 -0800
commitce32eee0999b60842c63cb7607b8bf9319242d5c (patch)
treebfe30ba3464800d2ba109c82bd67ede4b0268e71 /src/renderer
parent23e36f19255db60084c2c240a166d137f6c12c3e (diff)
downloadalacritty-ce32eee0999b60842c63cb7607b8bf9319242d5c.tar.gz
alacritty-ce32eee0999b60842c63cb7607b8bf9319242d5c.zip
Refactor color list management
There's now a ColorList type that provides strongly typed indexing for not only usize but NamedColor as well. Previously, the `NamedColor` was casted to a `usize` when indexing the colors. Additionally, only one copy of the ColorList needs to exist;it's borrowed from the `Config` when rendering, and the renderer doesn't need a copy.
Diffstat (limited to 'src/renderer')
-rw-r--r--src/renderer/mod.rs45
1 files changed, 23 insertions, 22 deletions
diff --git a/src/renderer/mod.rs b/src/renderer/mod.rs
index 2073be30..2728ad5f 100644
--- a/src/renderer/mod.rs
+++ b/src/renderer/mod.rs
@@ -28,7 +28,7 @@ use index::{Line, Column};
use ansi::{Color, NamedColor};
-use config::Config;
+use config::{Config, ColorList};
use term::{self, cell, IndexedCell, Cell};
use super::Rgb;
@@ -243,7 +243,6 @@ pub struct QuadRenderer {
atlas: Vec<Atlas>,
active_tex: GLuint,
batch: Batch,
- colors: Vec<Rgb>,
draw_bold_text_with_bright_colors: bool,
rx: mpsc::Receiver<Msg>,
}
@@ -254,7 +253,7 @@ pub struct RenderApi<'a> {
batch: &'a mut Batch,
atlas: &'a mut Vec<Atlas>,
program: &'a mut ShaderProgram,
- colors: &'a [Rgb],
+ colors: &'a ColorList,
}
#[derive(Debug)]
@@ -273,7 +272,6 @@ pub struct PackedVertex {
pub struct Batch {
tex: GLuint,
instances: Vec<InstanceData>,
- colors: Vec<Rgb>,
draw_bold_text_with_bright_colors: bool,
}
@@ -283,12 +281,16 @@ impl Batch {
Batch {
tex: 0,
instances: Vec::with_capacity(BATCH_MAX),
- colors: config.color_list(),
draw_bold_text_with_bright_colors: config.draw_bold_text_with_bright_colors(),
}
}
- pub fn add_item(&mut self, cell: &IndexedCell, glyph: &Glyph) {
+ pub fn add_item(
+ &mut self,
+ cell: &IndexedCell,
+ glyph: &Glyph,
+ colors: &ColorList
+ ) {
if self.is_empty() {
self.tex = glyph.tex_id;
}
@@ -296,13 +298,10 @@ impl Batch {
let fg = match cell.fg {
Color::Spec(rgb) => rgb,
Color::Named(ansi) => {
- if self.draw_bold_text_with_bright_colors
- && cell.bold()
- && ansi < NamedColor::BrightBlack
- {
- self.colors[ansi as usize + 8]
+ if self.draw_bold_text_with_bright_colors && cell.bold() {
+ colors[ansi.to_bright()]
} else {
- self.colors[ansi as usize]
+ colors[ansi]
}
},
Color::Indexed(idx) => {
@@ -315,14 +314,14 @@ impl Batch {
idx
};
- self.colors[idx as usize]
+ colors[idx]
}
};
let bg = match cell.bg {
Color::Spec(rgb) => rgb,
- Color::Named(ansi) => self.colors[ansi as usize],
- Color::Indexed(idx) => self.colors[idx as usize],
+ Color::Named(ansi) => colors[ansi],
+ Color::Indexed(idx) => colors[idx],
};
self.instances.push(InstanceData {
@@ -528,7 +527,6 @@ impl QuadRenderer {
atlas: Vec::new(),
active_tex: 0,
batch: Batch::new(config),
- colors: config.color_list(),
rx: msg_rx,
draw_bold_text_with_bright_colors: config.draw_bold_text_with_bright_colors(),
};
@@ -540,12 +538,15 @@ impl QuadRenderer {
}
pub fn update_config(&mut self, config: &Config) {
- self.colors = config.color_list();
- self.batch.colors = config.color_list();
self.batch.draw_bold_text_with_bright_colors = config.draw_bold_text_with_bright_colors();
}
- pub fn with_api<F, T>(&mut self, props: &term::SizeInfo, func: F) -> T
+ pub fn with_api<F, T>(
+ &mut self,
+ config: &Config,
+ props: &term::SizeInfo,
+ func: F
+ ) -> T
where F: FnOnce(RenderApi) -> T
{
while let Ok(msg) = self.rx.try_recv() {
@@ -571,7 +572,7 @@ impl QuadRenderer {
batch: &mut self.batch,
atlas: &mut self.atlas,
program: &mut self.program,
- colors: &self.colors,
+ colors: &config.color_list(),
});
unsafe {
@@ -635,7 +636,7 @@ impl QuadRenderer {
impl<'a> RenderApi<'a> {
pub fn clear(&self) {
- let color = self.colors[NamedColor::Background as usize];
+ let color = self.colors[NamedColor::Background];
unsafe {
gl::ClearColor(
color.r as f32 / 255.0,
@@ -712,7 +713,7 @@ impl<'a> RenderApi<'a> {
}
}
- self.batch.add_item(cell, glyph);
+ self.batch.add_item(cell, glyph, self.colors);
// Render batch and clear if it's full
if self.batch.full() {