1 Commits

Author SHA1 Message Date
baaea45d43 Keep tray Away/Back actions enabled 2026-03-25 17:54:45 -06:00
13 changed files with 206 additions and 165 deletions

File diff suppressed because one or more lines are too long

Before

Width:  |  Height:  |  Size: 4.8 KiB

After

Width:  |  Height:  |  Size: 250 KiB

File diff suppressed because one or more lines are too long

Before

Width:  |  Height:  |  Size: 4.8 KiB

After

Width:  |  Height:  |  Size: 250 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 129 KiB

After

Width:  |  Height:  |  Size: 4.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.8 KiB

After

Width:  |  Height:  |  Size: 2.7 KiB

File diff suppressed because one or more lines are too long

Before

Width:  |  Height:  |  Size: 4.8 KiB

After

Width:  |  Height:  |  Size: 250 KiB

View File

@@ -396,10 +396,14 @@ cmd_away (struct session *sess, char *tbuf, char *word[], char *word_eol[])
static int static int
cmd_back (struct session *sess, char *tbuf, char *word[], char *word_eol[]) cmd_back (struct session *sess, char *tbuf, char *word[], char *word_eol[])
{ {
if (sess->server->is_away) if (sess->server->connected)
{ {
sess->server->p_set_back (sess->server); sess->server->p_set_back (sess->server);
} }
else if (sess->server->reconnect_away)
{
sess->server->reconnect_away = FALSE;
}
else else
{ {
PrintText (sess, _("Already marked back.\n")); PrintText (sess, _("Already marked back.\n"));

View File

@@ -964,7 +964,7 @@ tray_find_away_status (void)
{ {
serv = list->data; serv = list->data;
if (serv->is_away || serv->reconnect_away) if (serv->is_away || serv->reconnect_away || serv->last_away_reason)
away++; away++;
else else
back++; back++;
@@ -1090,7 +1090,6 @@ tray_menu_populate (GtkWidget *menu)
{ {
GtkWidget *submenu; GtkWidget *submenu;
GtkWidget *item; GtkWidget *item;
int away_status;
/* ph may have an invalid context now */ /* ph may have an invalid context now */
zoitechat_set_context (ph, zoitechat_find_context (ph, NULL, NULL)); zoitechat_set_context (ph, zoitechat_find_context (ph, NULL, NULL));
@@ -1113,13 +1112,8 @@ tray_menu_populate (GtkWidget *menu)
submenu = menu; submenu = menu;
#endif #endif
away_status = tray_find_away_status ();
item = tray_make_item (submenu, _("_Away"), tray_foreach_server, "away"); item = tray_make_item (submenu, _("_Away"), tray_foreach_server, "away");
if (away_status == 1)
gtk_widget_set_sensitive (item, FALSE);
item = tray_make_item (submenu, _("_Back"), tray_foreach_server, "back"); item = tray_make_item (submenu, _("_Back"), tray_foreach_server, "back");
if (away_status == 2)
gtk_widget_set_sensitive (item, FALSE);
menu_add_plugin_items (menu, "\x5$TRAY", NULL); menu_add_plugin_items (menu, "\x5$TRAY", NULL);

View File

@@ -1136,6 +1136,7 @@ check_color:
{ {
if (text[i] == ',' && parsing_color <= 3) if (text[i] == ',' && parsing_color <= 3)
{ {
insert_hiddenchar (entry, i, i + 1);
parsing_color = 3; parsing_color = 3;
offset++; offset++;
continue; continue;
@@ -1152,21 +1153,25 @@ check_color:
{ {
case 1: case 1:
fg_color[0] = text[i]; fg_color[0] = text[i];
insert_hiddenchar (entry, i, i + 1);
parsing_color++; parsing_color++;
offset++; offset++;
continue; continue;
case 2: case 2:
fg_color[1] = text[i]; fg_color[1] = text[i];
insert_hiddenchar (entry, i, i + 1);
parsing_color++; parsing_color++;
offset++; offset++;
continue; continue;
case 3: case 3:
bg_color[0] = text[i]; bg_color[0] = text[i];
insert_hiddenchar (entry, i, i + 1);
parsing_color++; parsing_color++;
offset++; offset++;
continue; continue;
case 4: case 4:
bg_color[1] = text[i]; bg_color[1] = text[i];
insert_hiddenchar (entry, i, i + 1);
parsing_color++; parsing_color++;
offset++; offset++;
continue; continue;
@@ -1201,14 +1206,17 @@ check_color:
{ {
if (bg_color[0] != 0) if (bg_color[0] != 0)
{ {
insert_hiddenchar (entry, len - offset, len);
insert_color (entry, len, atoi (fg_color), atoi (bg_color)); insert_color (entry, len, atoi (fg_color), atoi (bg_color));
} }
else if (fg_color[0] != 0) else if (fg_color[0] != 0)
{ {
insert_hiddenchar (entry, len - offset, len);
insert_color (entry, len, atoi (fg_color), -1); insert_color (entry, len, atoi (fg_color), -1);
} }
else else
{ {
insert_hiddenchar (entry, len - offset, len - offset + 1);
insert_color (entry, len, -1, -1); insert_color (entry, len, -1, -1);
} }
} }

View File

@@ -27,47 +27,10 @@
enum enum
{ {
THEME_XTEXT_MIRC_COLS = 99, THEME_XTEXT_FG_INDEX = 34,
THEME_XTEXT_MARK_FG_INDEX = 99, THEME_XTEXT_BG_INDEX = 35
THEME_XTEXT_MARK_BG_INDEX = 100,
THEME_XTEXT_FG_INDEX = 101,
THEME_XTEXT_BG_INDEX = 102,
THEME_XTEXT_MARKER_INDEX = 103
}; };
static const guint8 theme_default_99_mirc_colors[THEME_XTEXT_MIRC_COLS][3] = {
{ 0xff, 0xff, 0xff }, { 0x00, 0x00, 0x00 }, { 0x00, 0x00, 0x7f }, { 0x00, 0x93, 0x00 }, { 0xff, 0x00, 0x00 }, { 0x7f, 0x00, 0x00 }, { 0x9c, 0x00, 0x9c }, { 0xfc, 0x7f, 0x00 },
{ 0xff, 0xff, 0x00 }, { 0x00, 0xfc, 0x00 }, { 0x00, 0x93, 0x93 }, { 0x00, 0xff, 0xff }, { 0x00, 0x00, 0xfc }, { 0xff, 0x00, 0xff }, { 0x7f, 0x7f, 0x7f }, { 0xd2, 0xd2, 0xd2 },
{ 0x47, 0x00, 0x00 }, { 0x47, 0x21, 0x00 }, { 0x47, 0x47, 0x00 }, { 0x32, 0x47, 0x00 }, { 0x00, 0x47, 0x00 }, { 0x00, 0x47, 0x2c }, { 0x00, 0x47, 0x47 }, { 0x00, 0x2f, 0x47 },
{ 0x00, 0x00, 0x47 }, { 0x2e, 0x00, 0x47 }, { 0x47, 0x00, 0x47 }, { 0x47, 0x00, 0x2a }, { 0x74, 0x00, 0x00 }, { 0x74, 0x3a, 0x00 }, { 0x74, 0x74, 0x00 }, { 0x51, 0x74, 0x00 },
{ 0x00, 0x74, 0x00 }, { 0x00, 0x74, 0x49 }, { 0x00, 0x74, 0x74 }, { 0x00, 0x4d, 0x74 }, { 0x00, 0x00, 0x74 }, { 0x4b, 0x00, 0x74 }, { 0x74, 0x00, 0x74 }, { 0x74, 0x00, 0x45 },
{ 0xb5, 0x00, 0x00 }, { 0xb5, 0x63, 0x00 }, { 0xb5, 0xb5, 0x00 }, { 0x7d, 0xb5, 0x00 }, { 0x00, 0xb5, 0x00 }, { 0x00, 0xb5, 0x71 }, { 0x00, 0xb5, 0xb5 }, { 0x00, 0x75, 0xb5 },
{ 0x00, 0x00, 0xb5 }, { 0x75, 0x00, 0xb5 }, { 0xb5, 0x00, 0xb5 }, { 0xb5, 0x00, 0x6b }, { 0xff, 0x00, 0x00 }, { 0xff, 0x8c, 0x00 }, { 0xff, 0xff, 0x00 }, { 0xb2, 0xff, 0x00 },
{ 0x00, 0xff, 0x00 }, { 0x00, 0xff, 0xa0 }, { 0x00, 0xff, 0xff }, { 0x00, 0xa9, 0xff }, { 0x00, 0x00, 0xff }, { 0xa5, 0x00, 0xff }, { 0xff, 0x00, 0xff }, { 0xff, 0x00, 0x98 },
{ 0xff, 0x59, 0x59 }, { 0xff, 0xb4, 0x59 }, { 0xff, 0xff, 0x71 }, { 0xcf, 0xff, 0x60 }, { 0x6f, 0xff, 0x6f }, { 0x65, 0xff, 0xc9 }, { 0x6d, 0xff, 0xff }, { 0x59, 0xcd, 0xff },
{ 0x59, 0x59, 0xff }, { 0xc4, 0x59, 0xff }, { 0xff, 0x66, 0xff }, { 0xff, 0x59, 0xbc }, { 0xff, 0x9c, 0x9c }, { 0xff, 0xd3, 0x9c }, { 0xff, 0xff, 0x9c }, { 0xe2, 0xff, 0x9c },
{ 0x9c, 0xff, 0x9c }, { 0x9c, 0xff, 0xdb }, { 0x9c, 0xff, 0xff }, { 0x9c, 0xe2, 0xff }, { 0x9c, 0x9c, 0xff }, { 0xdc, 0x9c, 0xff }, { 0xff, 0x9c, 0xff }, { 0xff, 0x94, 0xd3 },
{ 0x00, 0x00, 0x00 }, { 0x13, 0x13, 0x13 }, { 0x28, 0x28, 0x28 }, { 0x36, 0x36, 0x36 }, { 0x4d, 0x4d, 0x4d }, { 0x65, 0x65, 0x65 }, { 0x81, 0x81, 0x81 }, { 0x9f, 0x9f, 0x9f },
{ 0xbc, 0xbc, 0xbc }, { 0xe2, 0xe2, 0xe2 }, { 0xff, 0xff, 0xff }
};
static void
theme_access_apply_default_99_palette (XTextColor *palette, size_t palette_len, gboolean apply_base)
{
size_t i;
size_t start = apply_base ? 0 : 32;
if (palette_len == 0)
return;
for (i = start; i < THEME_XTEXT_MIRC_COLS && i < palette_len; i++)
{
palette[i].red = theme_default_99_mirc_colors[i][0] / 255.0;
palette[i].green = theme_default_99_mirc_colors[i][1] / 255.0;
palette[i].blue = theme_default_99_mirc_colors[i][2] / 255.0;
palette[i].alpha = 1.0;
}
}
static gboolean static gboolean
theme_token_to_rgb16 (ThemeSemanticToken token, guint16 *red, guint16 *green, guint16 *blue) theme_token_to_rgb16 (ThemeSemanticToken token, guint16 *red, guint16 *green, guint16 *blue)
{ {
@@ -120,18 +83,9 @@ gboolean
theme_get_mirc_color (unsigned int mirc_index, GdkRGBA *out_rgba) theme_get_mirc_color (unsigned int mirc_index, GdkRGBA *out_rgba)
{ {
ThemeSemanticToken token = (ThemeSemanticToken) (THEME_TOKEN_MIRC_0 + (int) mirc_index); ThemeSemanticToken token = (ThemeSemanticToken) (THEME_TOKEN_MIRC_0 + (int) mirc_index);
gboolean has_user_colors = theme_runtime_mode_has_user_colors (theme_runtime_is_dark_active ());
if (mirc_index >= THEME_XTEXT_MIRC_COLS) if (mirc_index >= 32)
return FALSE; return FALSE;
if (!has_user_colors || mirc_index >= 32)
{
out_rgba->red = theme_default_99_mirc_colors[mirc_index][0] / 255.0;
out_rgba->green = theme_default_99_mirc_colors[mirc_index][1] / 255.0;
out_rgba->blue = theme_default_99_mirc_colors[mirc_index][2] / 255.0;
out_rgba->alpha = 1.0;
return TRUE;
}
return theme_runtime_get_color (token, out_rgba); return theme_runtime_get_color (token, out_rgba);
} }
@@ -145,17 +99,9 @@ gboolean
theme_get_mirc_color_rgb16 (unsigned int mirc_index, guint16 *red, guint16 *green, guint16 *blue) theme_get_mirc_color_rgb16 (unsigned int mirc_index, guint16 *red, guint16 *green, guint16 *blue)
{ {
ThemeSemanticToken token = (ThemeSemanticToken) (THEME_TOKEN_MIRC_0 + (int) mirc_index); ThemeSemanticToken token = (ThemeSemanticToken) (THEME_TOKEN_MIRC_0 + (int) mirc_index);
gboolean has_user_colors = theme_runtime_mode_has_user_colors (theme_runtime_is_dark_active ());
if (mirc_index >= THEME_XTEXT_MIRC_COLS) if (mirc_index >= 32)
return FALSE; return FALSE;
if (!has_user_colors || mirc_index >= 32)
{
*red = (guint16) (theme_default_99_mirc_colors[mirc_index][0] * 257);
*green = (guint16) (theme_default_99_mirc_colors[mirc_index][1] * 257);
*blue = (guint16) (theme_default_99_mirc_colors[mirc_index][2] * 257);
return TRUE;
}
return theme_token_to_rgb16 (token, red, green, blue); return theme_token_to_rgb16 (token, red, green, blue);
} }
@@ -199,39 +145,12 @@ void
theme_get_xtext_colors_for_widget (GtkWidget *widget, XTextColor *palette, size_t palette_len) theme_get_xtext_colors_for_widget (GtkWidget *widget, XTextColor *palette, size_t palette_len)
{ {
ThemeWidgetStyleValues style_values; ThemeWidgetStyleValues style_values;
gboolean has_user_colors;
GdkRGBA marker_color;
if (!palette) if (!palette)
return; return;
theme_get_widget_style_values_for_widget (widget, &style_values); theme_get_widget_style_values_for_widget (widget, &style_values);
theme_runtime_get_xtext_colors (palette, palette_len); theme_runtime_get_xtext_colors (palette, palette_len);
has_user_colors = theme_runtime_mode_has_user_colors (theme_runtime_is_dark_active ());
theme_access_apply_default_99_palette (palette, palette_len, !has_user_colors);
if (palette_len > THEME_XTEXT_MARK_FG_INDEX)
{
palette[THEME_XTEXT_MARK_FG_INDEX].red = style_values.selection_foreground.red;
palette[THEME_XTEXT_MARK_FG_INDEX].green = style_values.selection_foreground.green;
palette[THEME_XTEXT_MARK_FG_INDEX].blue = style_values.selection_foreground.blue;
palette[THEME_XTEXT_MARK_FG_INDEX].alpha = style_values.selection_foreground.alpha;
}
if (palette_len > THEME_XTEXT_MARK_BG_INDEX)
{
palette[THEME_XTEXT_MARK_BG_INDEX].red = style_values.selection_background.red;
palette[THEME_XTEXT_MARK_BG_INDEX].green = style_values.selection_background.green;
palette[THEME_XTEXT_MARK_BG_INDEX].blue = style_values.selection_background.blue;
palette[THEME_XTEXT_MARK_BG_INDEX].alpha = style_values.selection_background.alpha;
}
if (palette_len > THEME_XTEXT_MARKER_INDEX)
{
if (!theme_runtime_get_color (THEME_TOKEN_MARKER, &marker_color))
marker_color = style_values.selection_background;
palette[THEME_XTEXT_MARKER_INDEX].red = marker_color.red;
palette[THEME_XTEXT_MARKER_INDEX].green = marker_color.green;
palette[THEME_XTEXT_MARKER_INDEX].blue = marker_color.blue;
palette[THEME_XTEXT_MARKER_INDEX].alpha = marker_color.alpha;
}
if (palette_len > THEME_XTEXT_FG_INDEX) if (palette_len > THEME_XTEXT_FG_INDEX)
{ {
palette[THEME_XTEXT_FG_INDEX].red = style_values.foreground.red; palette[THEME_XTEXT_FG_INDEX].red = style_values.foreground.red;

View File

@@ -427,6 +427,7 @@ enum
GTK3_THEME_COL_ID = 0, GTK3_THEME_COL_ID = 0,
GTK3_THEME_COL_LABEL, GTK3_THEME_COL_LABEL,
GTK3_THEME_COL_SOURCE, GTK3_THEME_COL_SOURCE,
GTK3_THEME_COL_THUMBNAIL,
GTK3_THEME_COL_COUNT GTK3_THEME_COL_COUNT
}; };
@@ -1402,6 +1403,25 @@ theme_preferences_gtk3_changed_cb (GtkComboBox *combo, gpointer user_data)
g_free (id); g_free (id);
} }
static GdkPixbuf *
theme_preferences_load_thumbnail (const char *path)
{
GError *error = NULL;
GdkPixbuf *pixbuf;
if (!path)
return NULL;
pixbuf = gdk_pixbuf_new_from_file_at_scale (path, 48, 48, TRUE, &error);
if (!pixbuf)
{
g_clear_error (&error);
return NULL;
}
return pixbuf;
}
static int static int
theme_preferences_gtk3_find_system_theme_index (GPtrArray *themes) theme_preferences_gtk3_find_system_theme_index (GPtrArray *themes)
{ {
@@ -1460,15 +1480,22 @@ theme_preferences_populate_gtk3 (theme_preferences_ui *ui)
ZoitechatGtk3Theme *theme = g_ptr_array_index (themes, i); ZoitechatGtk3Theme *theme = g_ptr_array_index (themes, i);
char *label = g_strdup_printf ("%s (%s)", theme->display_name, char *label = g_strdup_printf ("%s (%s)", theme->display_name,
theme->source == ZOITECHAT_GTK3_THEME_SOURCE_USER ? _("user") : _("system")); theme->source == ZOITECHAT_GTK3_THEME_SOURCE_USER ? _("user") : _("system"));
GdkPixbuf *thumbnail = NULL;
if (theme->thumbnail_path && g_file_test (theme->thumbnail_path, G_FILE_TEST_IS_REGULAR))
thumbnail = theme_preferences_load_thumbnail (theme->thumbnail_path);
gtk_tree_store_append (store, &iter, NULL); gtk_tree_store_append (store, &iter, NULL);
gtk_tree_store_set (store, &iter, gtk_tree_store_set (store, &iter,
GTK3_THEME_COL_ID, theme->id, GTK3_THEME_COL_ID, theme->id,
GTK3_THEME_COL_LABEL, label, GTK3_THEME_COL_LABEL, label,
GTK3_THEME_COL_SOURCE, theme->source, GTK3_THEME_COL_SOURCE, theme->source,
GTK3_THEME_COL_THUMBNAIL, thumbnail,
-1); -1);
if (g_strcmp0 (prefs.hex_gui_gtk3_theme, theme->id) == 0) if (g_strcmp0 (prefs.hex_gui_gtk3_theme, theme->id) == 0)
active = i; active = i;
if (thumbnail)
g_object_unref (thumbnail);
g_free (label); g_free (label);
} }
if (active < 0 && using_system_default) if (active < 0 && using_system_default)
@@ -1653,9 +1680,13 @@ theme_preferences_create_page (GtkWindow *parent,
gtk3_store = gtk_tree_store_new (GTK3_THEME_COL_COUNT, gtk3_store = gtk_tree_store_new (GTK3_THEME_COL_COUNT,
G_TYPE_STRING, G_TYPE_STRING,
G_TYPE_STRING, G_TYPE_STRING,
G_TYPE_INT); G_TYPE_INT,
GDK_TYPE_PIXBUF);
ui->gtk3_combo = gtk_combo_box_new_with_model (GTK_TREE_MODEL (gtk3_store)); ui->gtk3_combo = gtk_combo_box_new_with_model (GTK_TREE_MODEL (gtk3_store));
g_object_unref (gtk3_store); g_object_unref (gtk3_store);
renderer = gtk_cell_renderer_pixbuf_new ();
gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (ui->gtk3_combo), renderer, FALSE);
gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (ui->gtk3_combo), renderer, "pixbuf", GTK3_THEME_COL_THUMBNAIL);
renderer = gtk_cell_renderer_text_new (); renderer = gtk_cell_renderer_text_new ();
gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (ui->gtk3_combo), renderer, TRUE); gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (ui->gtk3_combo), renderer, TRUE);
gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (ui->gtk3_combo), renderer, "text", GTK3_THEME_COL_LABEL); gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (ui->gtk3_combo), renderer, "text", GTK3_THEME_COL_LABEL);

View File

@@ -326,8 +326,7 @@ theme_runtime_get_color (ThemeSemanticToken token, GdkRGBA *out_rgba)
gboolean gboolean
theme_runtime_mode_has_user_colors (gboolean dark_mode) theme_runtime_mode_has_user_colors (gboolean dark_mode)
{ {
if (dark_mode) (void) dark_mode;
return dark_user_colors_valid;
return user_colors_valid; return user_colors_valid;
} }
@@ -468,6 +467,7 @@ theme_runtime_load (void)
active_palette = light_palette; active_palette = light_palette;
dark_mode_active = FALSE; dark_mode_active = FALSE;
user_colors_valid = TRUE;
} }
static gboolean static gboolean

View File

@@ -2311,16 +2311,7 @@ gtk_xtext_motion_notify (GtkWidget * widget, GdkEventMotion * event)
if (!window) if (!window)
return FALSE; return FALSE;
if (event->is_hint) gtk_xtext_get_pointer (window, &x, &y, &mask);
{
gtk_xtext_get_pointer (window, &x, &y, &mask);
}
else
{
x = (int)event->x;
y = (int)event->y;
mask = event->state;
}
if (xtext->moving_separator) if (xtext->moving_separator)
{ {
@@ -2496,12 +2487,9 @@ gtk_xtext_button_release (GtkWidget * widget, GdkEventButton * event)
GtkXText *xtext = GTK_XTEXT (widget); GtkXText *xtext = GTK_XTEXT (widget);
unsigned char *word; unsigned char *word;
int old; int old;
int event_x, event_y;
GtkAllocation allocation; GtkAllocation allocation;
gtk_widget_get_allocation (widget, &allocation); gtk_widget_get_allocation (widget, &allocation);
event_x = (int)event->x;
event_y = (int)event->y;
if (xtext->moving_separator) if (xtext->moving_separator)
{ {
@@ -2551,8 +2539,8 @@ gtk_xtext_button_release (GtkWidget * widget, GdkEventButton * event)
return FALSE; return FALSE;
} }
if (xtext->select_start_x == event_x && if (xtext->select_start_x == event->x &&
xtext->select_start_y == event_y && xtext->select_start_y == event->y &&
xtext->buffer->last_ent_start) xtext->buffer->last_ent_start)
{ {
gtk_xtext_unselect (xtext); gtk_xtext_unselect (xtext);
@@ -2562,7 +2550,7 @@ gtk_xtext_button_release (GtkWidget * widget, GdkEventButton * event)
if (!gtk_xtext_is_selecting (xtext)) if (!gtk_xtext_is_selecting (xtext))
{ {
word = gtk_xtext_get_word (xtext, event_x, event_y, 0, 0, 0, 0); word = gtk_xtext_get_word (xtext, event->x, event->y, 0, 0, 0, 0);
g_signal_emit (G_OBJECT (xtext), xtext_signals[WORD_CLICK], 0, word ? word : NULL, event); g_signal_emit (G_OBJECT (xtext), xtext_signals[WORD_CLICK], 0, word ? word : NULL, event);
} }
} }
@@ -2584,9 +2572,7 @@ gtk_xtext_button_press (GtkWidget * widget, GdkEventButton * event)
if (!window) if (!window)
return FALSE; return FALSE;
x = (int)event->x; gtk_xtext_get_pointer (window, &x, &y, &mask);
y = (int)event->y;
mask = event->state;
if (event->button == 3 || event->button == 2) /* right/middle click */ if (event->button == 3 || event->button == 2) /* right/middle click */
{ {

View File

@@ -49,14 +49,14 @@ GType gtk_xtext_get_type (void);
#define ATTR_UNDERLINE '\037' #define ATTR_UNDERLINE '\037'
/* these match palette.h */ /* these match palette.h */
#define XTEXT_MIRC_COLS 99 #define XTEXT_MIRC_COLS 32
#define XTEXT_COLS 104 /* 99 plus 5 for extra stuff below */ #define XTEXT_COLS 37 /* 32 plus 5 for extra stuff below */
#define XTEXT_MARK_FG 99 /* for marking text */ #define XTEXT_MARK_FG 32 /* for marking text */
#define XTEXT_MARK_BG 100 #define XTEXT_MARK_BG 33
#define XTEXT_FG 101 #define XTEXT_FG 34
#define XTEXT_BG 102 #define XTEXT_BG 35
#define XTEXT_MARKER 103 /* for marker line */ #define XTEXT_MARKER 36 /* for marker line */
#define XTEXT_MAX_COLOR 98 #define XTEXT_MAX_COLOR 41
typedef struct textentry textentry; typedef struct textentry textentry;
/* /*