X-Git-Url: https://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fjexer%2Fbits%2FColorTheme.java;h=caf7b434d59e16912025113754817dcdb4f8e96a;hb=b6faeac0d9c3e3ae3376ed28b54ec6ea6408ad7a;hp=1c7c62092c4f7ab7d20048fbad027e380066c4d4;hpb=68c5cd6bec3dc425ef5b55fec399d4bdc9afa7cb;p=fanfix.git diff --git a/src/jexer/bits/ColorTheme.java b/src/jexer/bits/ColorTheme.java index 1c7c620..caf7b43 100644 --- a/src/jexer/bits/ColorTheme.java +++ b/src/jexer/bits/ColorTheme.java @@ -130,27 +130,39 @@ public final class ColorTheme { String line = bufferedReader.readLine(); for (; line != null; line = bufferedReader.readLine()) { String key; - String bold; + boolean bold = false; + boolean blink = false; String foreColor; String backColor; + String token; // Look for lines that resemble: // "key = blah on blah" // "key = bold blah on blah" + // "key = blink bold blah on blah" + // "key = bold blink blah on blah" + // "key = blink blah on blah" StringTokenizer tokenizer = new StringTokenizer(line); key = tokenizer.nextToken(); if (!tokenizer.nextToken().equals("=")) { // Skip this line continue; } - bold = tokenizer.nextToken(); - if (!bold.toLowerCase().equals("bold")) { - // "key = blah on blah" - foreColor = bold; - } else { - // "key = bold blah on blah" - foreColor = tokenizer.nextToken().toLowerCase(); + token = tokenizer.nextToken(); + while (token.equals("bold") || token.equals("blink")) { + if (token.equals("bold")) { + bold = true; + token = tokenizer.nextToken(); + } + if (token.equals("blink")) { + blink = true; + token = tokenizer.nextToken(); + } } + + // What's left is "blah on blah" or "blah" + foreColor = token.toLowerCase(); + if (!tokenizer.nextToken().toLowerCase().equals("on")) { // Skip this line continue; @@ -158,9 +170,12 @@ public final class ColorTheme { backColor = tokenizer.nextToken().toLowerCase(); CellAttributes color = new CellAttributes(); - if (bold.equals("bold")) { + if (bold) { color.setBold(true); } + if (blink) { + color.setBlink(true); + } color.setForeColor(Color.getColor(foreColor)); color.setBackColor(Color.getColor(backColor)); colors.put(key, color); @@ -324,7 +339,6 @@ public final class ColorTheme { color.setBold(true); colors.put("tcheckbox.active", color); - // TRadioButton color = new CellAttributes(); color.setForeColor(Color.WHITE); @@ -422,9 +436,12 @@ public final class ColorTheme { color.setBold(false); colors.put("ttreeview.unreadable", color); color = new CellAttributes(); - color.setForeColor(Color.BLACK); + // color.setForeColor(Color.BLACK); + // color.setBackColor(Color.BLUE); + // color.setBold(true); + color.setForeColor(Color.WHITE); color.setBackColor(Color.BLUE); - color.setBold(true); + color.setBold(false); colors.put("ttreeview.inactive", color); // TList @@ -444,9 +461,12 @@ public final class ColorTheme { color.setBold(false); colors.put("tlist.unreadable", color); color = new CellAttributes(); - color.setForeColor(Color.BLACK); + // color.setForeColor(Color.BLACK); + // color.setBackColor(Color.BLUE); + // color.setBold(true); + color.setForeColor(Color.WHITE); color.setBackColor(Color.BLUE); - color.setBold(true); + color.setBold(false); colors.put("tlist.inactive", color); // TStatusBar