Compare commits
No commits in common. "00b47d7ded68f3dc6d9d032cb9d6525354eb8e55" and "73e4806e650b80b7a3b3f970fbc132c2090cff5b" have entirely different histories.
00b47d7ded
...
73e4806e65
@ -35,12 +35,6 @@
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief gds_tree_check_cell_references checks if all child cell references can be resolved in the given library
|
* @brief gds_tree_check_cell_references checks if all child cell references can be resolved in the given library
|
||||||
*
|
|
||||||
* This function will only mark cells that
|
|
||||||
* directly contain unresolved references.
|
|
||||||
*
|
|
||||||
* If a cell contains a reference to a cell with unresolved references, it is not flagged.
|
|
||||||
*
|
|
||||||
* @param lib The GDS library to check
|
* @param lib The GDS library to check
|
||||||
* @return less than 0 if an error occured during processing; 0 if all child cells could be resolved;
|
* @return less than 0 if an error occured during processing; 0 if all child cells could be resolved;
|
||||||
* greater than zero if the processing was successful but not all cell references could be resolved.
|
* greater than zero if the processing was successful but not all cell references could be resolved.
|
||||||
|
@ -37,7 +37,6 @@
|
|||||||
#include "widgets/conv-settings-dialog.h"
|
#include "widgets/conv-settings-dialog.h"
|
||||||
#include "cairo-output/cairo-output.h"
|
#include "cairo-output/cairo-output.h"
|
||||||
#include "trigonometric/cell-trigonometrics.h"
|
#include "trigonometric/cell-trigonometrics.h"
|
||||||
#include "tree-renderer/lib-cell-renderer.h"
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief User data supplied to callback function of the open button
|
* @brief User data supplied to callback function of the open button
|
||||||
@ -115,6 +114,7 @@ static void on_load_gds(gpointer button, gpointer user)
|
|||||||
char *filename;
|
char *filename;
|
||||||
GString *mod_date;
|
GString *mod_date;
|
||||||
GString *acc_date;
|
GString *acc_date;
|
||||||
|
GdkRGBA cell_text_color;
|
||||||
|
|
||||||
open_dialog = gtk_file_chooser_dialog_new("Open GDSII File", ptr->main_window, GTK_FILE_CHOOSER_ACTION_OPEN,
|
open_dialog = gtk_file_chooser_dialog_new("Open GDSII File", ptr->main_window, GTK_FILE_CHOOSER_ACTION_OPEN,
|
||||||
"Cancel", GTK_RESPONSE_CANCEL, "Open GDSII", GTK_RESPONSE_ACCEPT, NULL);
|
"Cancel", GTK_RESPONSE_CANCEL, "Open GDSII", GTK_RESPONSE_ACCEPT, NULL);
|
||||||
@ -175,6 +175,11 @@ static void on_load_gds(gpointer button, gpointer user)
|
|||||||
mod_date = generate_string_from_date(&gds_c->mod_time);
|
mod_date = generate_string_from_date(&gds_c->mod_time);
|
||||||
acc_date = generate_string_from_date(&gds_c->access_time);
|
acc_date = generate_string_from_date(&gds_c->access_time);
|
||||||
|
|
||||||
|
cell_text_color.alpha = 1;
|
||||||
|
cell_text_color.red = (double)61.0/(double)255.0;
|
||||||
|
cell_text_color.green = (double)152.0/(double)255.0;
|
||||||
|
cell_text_color.blue = 0.0;
|
||||||
|
|
||||||
/* Add cell to tree store model
|
/* Add cell to tree store model
|
||||||
* CELL_SEL_CELL_COLOR will always be green,
|
* CELL_SEL_CELL_COLOR will always be green,
|
||||||
* because no cell cehcker is implemented, yet.
|
* because no cell cehcker is implemented, yet.
|
||||||
@ -183,7 +188,7 @@ static void on_load_gds(gpointer button, gpointer user)
|
|||||||
CELL_SEL_CELL, gds_c,
|
CELL_SEL_CELL, gds_c,
|
||||||
CELL_SEL_MODDATE, mod_date->str,
|
CELL_SEL_MODDATE, mod_date->str,
|
||||||
CELL_SEL_ACCESSDATE, acc_date->str,
|
CELL_SEL_ACCESSDATE, acc_date->str,
|
||||||
CELL_SEL_CELL_ERROR_STATE, 0, // TODO: implement cell checker
|
CELL_SEL_CELL_COLOR, &cell_text_color, // TODO: implement cell checker
|
||||||
-1);
|
-1);
|
||||||
|
|
||||||
/* Delete GStrings including string data. */
|
/* Delete GStrings including string data. */
|
||||||
|
@ -25,7 +25,6 @@ G_DEFINE_TYPE(LibCellRenderer, lib_cell_renderer, GTK_TYPE_CELL_RENDERER_TEXT)
|
|||||||
enum {
|
enum {
|
||||||
PROP_LIB = 1,
|
PROP_LIB = 1,
|
||||||
PROP_CELL,
|
PROP_CELL,
|
||||||
PROP_ERROR_LEVEL,
|
|
||||||
PROP_COUNT
|
PROP_COUNT
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -39,56 +38,24 @@ static void lib_cell_renderer_constructed(GObject *obj)
|
|||||||
G_OBJECT_CLASS(lib_cell_renderer_parent_class)->constructed(obj);
|
G_OBJECT_CLASS(lib_cell_renderer_parent_class)->constructed(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void convert_error_level_to_color(GdkRGBA *color, unsigned int error_level)
|
|
||||||
{
|
|
||||||
|
|
||||||
/* Always use no transparency */
|
|
||||||
color->alpha = 1.0;
|
|
||||||
|
|
||||||
if (error_level & LIB_CELL_RENDERER_ERROR_ERR) {
|
|
||||||
/* Error set. Color cell red */
|
|
||||||
color->red = 1.0;
|
|
||||||
color->blue = 0.0;
|
|
||||||
color->green = 0.0;
|
|
||||||
} else if (error_level & LIB_CELL_RENDERER_ERROR_WARN) {
|
|
||||||
/* Only warning set; orange color */
|
|
||||||
color->red = 0.6;
|
|
||||||
color->blue = 0.0;
|
|
||||||
color->green = 0.4;
|
|
||||||
} else {
|
|
||||||
/* Everything okay; green color */
|
|
||||||
color->red = (double)61.0/(double)255.0;
|
|
||||||
color->green = (double)152.0/(double)255.0;
|
|
||||||
color->blue = 0.0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void lib_cell_renderer_set_property(GObject *object,
|
static void lib_cell_renderer_set_property(GObject *object,
|
||||||
guint param_id,
|
guint param_id,
|
||||||
const GValue *value,
|
const GValue *value,
|
||||||
GParamSpec *pspec)
|
GParamSpec *pspec)
|
||||||
{
|
{
|
||||||
GValue val = G_VALUE_INIT;
|
GValue val = G_VALUE_INIT;
|
||||||
GdkRGBA color;
|
|
||||||
|
g_value_init(&val, G_TYPE_STRING);
|
||||||
|
|
||||||
switch (param_id) {
|
switch (param_id) {
|
||||||
case PROP_LIB:
|
case PROP_LIB:
|
||||||
g_value_init(&val, G_TYPE_STRING);
|
|
||||||
g_value_set_string(&val, ((struct gds_library *)g_value_get_pointer(value))->name);
|
g_value_set_string(&val, ((struct gds_library *)g_value_get_pointer(value))->name);
|
||||||
g_object_set_property(object, "text", &val);
|
g_object_set_property(object, "text", &val);
|
||||||
break;
|
break;
|
||||||
case PROP_CELL:
|
case PROP_CELL:
|
||||||
g_value_init(&val, G_TYPE_STRING);
|
|
||||||
g_value_set_string(&val, ((struct gds_cell *)g_value_get_pointer(value))->name);
|
g_value_set_string(&val, ((struct gds_cell *)g_value_get_pointer(value))->name);
|
||||||
g_object_set_property(object, "text", &val);
|
g_object_set_property(object, "text", &val);
|
||||||
break;
|
break;
|
||||||
case PROP_ERROR_LEVEL:
|
|
||||||
/* Set cell color according to error level */
|
|
||||||
g_value_init(&val, GDK_TYPE_RGBA);
|
|
||||||
convert_error_level_to_color(&color, g_value_get_uint(value));
|
|
||||||
g_value_set_boxed(&val, &color);
|
|
||||||
g_object_set_property(object, "foreground-rgba", &val);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID(object, param_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID(object, param_id, pspec);
|
||||||
break;
|
break;
|
||||||
@ -122,8 +89,6 @@ void lib_cell_renderer_class_init(LibCellRendererClass *klass)
|
|||||||
properties[PROP_CELL] = g_param_spec_pointer("gds-cell", "gds-cell",
|
properties[PROP_CELL] = g_param_spec_pointer("gds-cell", "gds-cell",
|
||||||
"Cell reference to be displayed",
|
"Cell reference to be displayed",
|
||||||
G_PARAM_WRITABLE);
|
G_PARAM_WRITABLE);
|
||||||
properties[PROP_ERROR_LEVEL] = g_param_spec_uint("error-level", "error-level",
|
|
||||||
"Error level of this cell", 0, 255, 0, G_PARAM_WRITABLE);
|
|
||||||
|
|
||||||
g_object_class_install_properties(oclass, PROP_COUNT, properties);
|
g_object_class_install_properties(oclass, PROP_COUNT, properties);
|
||||||
}
|
}
|
||||||
|
@ -27,9 +27,6 @@ G_BEGIN_DECLS
|
|||||||
G_DECLARE_FINAL_TYPE(LibCellRenderer, lib_cell_renderer, LIB_CELL, RENDERER, GtkCellRendererText)
|
G_DECLARE_FINAL_TYPE(LibCellRenderer, lib_cell_renderer, LIB_CELL, RENDERER, GtkCellRendererText)
|
||||||
#define TYPE_LIB_CELL_RENDERER (lib_cell_renderer_get_type())
|
#define TYPE_LIB_CELL_RENDERER (lib_cell_renderer_get_type())
|
||||||
|
|
||||||
#define LIB_CELL_RENDERER_ERROR_WARN (1U<<0)
|
|
||||||
#define LIB_CELL_RENDERER_ERROR_ERR (1U<<1)
|
|
||||||
|
|
||||||
typedef struct _LibCellRenderer {
|
typedef struct _LibCellRenderer {
|
||||||
/* Inheritance */
|
/* Inheritance */
|
||||||
GtkCellRendererText super;
|
GtkCellRendererText super;
|
||||||
|
@ -127,7 +127,7 @@ struct tree_stores *setup_cell_selector(GtkTreeView* view, GtkEntry *search_entr
|
|||||||
stores.base_tree_view = view;
|
stores.base_tree_view = view;
|
||||||
stores.search_entry = search_entry;
|
stores.search_entry = search_entry;
|
||||||
|
|
||||||
stores.base_store = gtk_tree_store_new(CELL_SEL_COLUMN_COUNT, G_TYPE_POINTER, G_TYPE_POINTER, G_TYPE_UINT, G_TYPE_STRING, G_TYPE_STRING);
|
stores.base_store = gtk_tree_store_new(CELL_SEL_COLUMN_COUNT, G_TYPE_POINTER, G_TYPE_POINTER, GDK_TYPE_RGBA, G_TYPE_STRING, G_TYPE_STRING);
|
||||||
|
|
||||||
/* Searching */
|
/* Searching */
|
||||||
if (search_entry) {
|
if (search_entry) {
|
||||||
@ -147,8 +147,8 @@ struct tree_stores *setup_cell_selector(GtkTreeView* view, GtkEntry *search_entr
|
|||||||
column = gtk_tree_view_column_new_with_attributes("Library", render_lib, "gds-lib", CELL_SEL_LIBRARY, NULL);
|
column = gtk_tree_view_column_new_with_attributes("Library", render_lib, "gds-lib", CELL_SEL_LIBRARY, NULL);
|
||||||
gtk_tree_view_append_column(view, column);
|
gtk_tree_view_append_column(view, column);
|
||||||
|
|
||||||
column = gtk_tree_view_column_new_with_attributes("Cell", render_cell, "gds-cell", CELL_SEL_CELL,
|
/* Cell color: #3D9801 */
|
||||||
"error-level", CELL_SEL_CELL_ERROR_STATE, NULL);
|
column = gtk_tree_view_column_new_with_attributes("Cell", render_cell, "gds-cell", CELL_SEL_CELL, "foreground-rgba", CELL_SEL_CELL_COLOR, NULL);
|
||||||
gtk_tree_view_append_column(view, column);
|
gtk_tree_view_append_column(view, column);
|
||||||
|
|
||||||
column = gtk_tree_view_column_new_with_attributes("Mod. Date", render_dates, "text", CELL_SEL_MODDATE, NULL);
|
column = gtk_tree_view_column_new_with_attributes("Mod. Date", render_dates, "text", CELL_SEL_MODDATE, NULL);
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
enum cell_store_columns {
|
enum cell_store_columns {
|
||||||
CELL_SEL_LIBRARY = 0,
|
CELL_SEL_LIBRARY = 0,
|
||||||
CELL_SEL_CELL,
|
CELL_SEL_CELL,
|
||||||
CELL_SEL_CELL_ERROR_STATE, /**< Used for cell color and selectability */
|
CELL_SEL_CELL_COLOR, /**< Cell column color */
|
||||||
CELL_SEL_MODDATE,
|
CELL_SEL_MODDATE,
|
||||||
CELL_SEL_ACCESSDATE,
|
CELL_SEL_ACCESSDATE,
|
||||||
CELL_SEL_COLUMN_COUNT /**< Not a column. Used to determine count of coumns **/
|
CELL_SEL_COLUMN_COUNT /**< Not a column. Used to determine count of coumns **/
|
||||||
|
Loading…
Reference in New Issue
Block a user