2018-07-23 17:00:37 +02:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* GDSII-Converter
|
|
|
|
* Copyright (C) 2018 Mario Hüttel <mario.huettel@gmx.net>
|
|
|
|
*
|
|
|
|
* This file is part of GDSII-Converter.
|
|
|
|
*
|
|
|
|
* GDSII-Converter is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* GDSII-Converter is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with GDSII-Converter. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2018-07-24 17:45:16 +02:00
|
|
|
/**
|
|
|
|
* @file mapping-parser.c
|
|
|
|
* @brief Function to read a mapping file line and parse it.
|
|
|
|
* @author Mario Hüttel <mario.huettel@gmx.net>
|
|
|
|
*/
|
2018-07-23 17:00:37 +02:00
|
|
|
|
|
|
|
/**
|
2018-07-24 17:45:16 +02:00
|
|
|
* @addtogroup MainApplication
|
|
|
|
* @{
|
2018-07-23 17:00:37 +02:00
|
|
|
*/
|
2018-07-24 17:45:16 +02:00
|
|
|
|
2019-03-26 19:57:19 +01:00
|
|
|
#include <gds-render/layer/mapping-parser.h>
|
2018-07-24 17:45:16 +02:00
|
|
|
|
2019-03-25 17:56:57 +01:00
|
|
|
int mapping_parser_load_line(GDataInputStream *stream, gboolean *export, char **name, int *layer, GdkRGBA *color)
|
2018-07-23 17:00:37 +02:00
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
gsize len;
|
|
|
|
gchar *line;
|
|
|
|
GRegex *regex;
|
|
|
|
GMatchInfo *mi;
|
|
|
|
char *match;
|
|
|
|
|
|
|
|
if ((!export) || (!name) || (!layer) || (!color)) {
|
|
|
|
ret = 1;
|
|
|
|
goto ret_direct;
|
|
|
|
}
|
|
|
|
|
|
|
|
regex = g_regex_new("^(?<layer>[0-9]+),(?<r>[0-9\\.]+),(?<g>[0-9\\.]+),(?<b>[0-9\\.]+),(?<a>[0-9\\.]+),(?<export>[01]),(?<name>.*)$", 0, 0, NULL);
|
|
|
|
|
|
|
|
line = g_data_input_stream_read_line(stream, &len, NULL, NULL);
|
|
|
|
if (!line) {
|
|
|
|
ret = -1;
|
|
|
|
goto destroy_regex;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Match line in CSV */
|
|
|
|
g_regex_match(regex, line, 0, &mi);
|
|
|
|
if (g_match_info_matches(mi)) {
|
|
|
|
/* Line is valid */
|
|
|
|
match = g_match_info_fetch_named(mi, "layer");
|
|
|
|
*layer = (int)g_ascii_strtoll(match, NULL, 10);
|
|
|
|
g_free(match);
|
|
|
|
match = g_match_info_fetch_named(mi, "r");
|
|
|
|
color->red = g_ascii_strtod(match, NULL);
|
|
|
|
g_free(match);
|
|
|
|
match = g_match_info_fetch_named(mi, "g");
|
|
|
|
color->green = g_ascii_strtod(match, NULL);
|
|
|
|
g_free(match);
|
|
|
|
match = g_match_info_fetch_named(mi, "b");
|
|
|
|
color->blue = g_ascii_strtod(match, NULL);
|
|
|
|
g_free(match);
|
|
|
|
match = g_match_info_fetch_named(mi, "a");
|
|
|
|
color->alpha = g_ascii_strtod(match, NULL);
|
|
|
|
g_free(match);
|
|
|
|
match = g_match_info_fetch_named(mi, "export");
|
|
|
|
*export = ((!strcmp(match, "1")) ? TRUE : FALSE);
|
|
|
|
g_free(match);
|
|
|
|
match = g_match_info_fetch_named(mi, "name");
|
|
|
|
*name = match;
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
} else {
|
|
|
|
/* Line is malformatted */
|
|
|
|
printf("Could not recognize line in CSV as valid entry: %s\n", line);
|
|
|
|
ret = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_match_info_free(mi);
|
|
|
|
g_free(line);
|
|
|
|
destroy_regex:
|
|
|
|
g_regex_unref(regex);
|
|
|
|
ret_direct:
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-03-25 17:56:57 +01:00
|
|
|
void mapping_parser_gen_csv_line(LayerElement *layer_element, char *line_buffer, size_t max_len)
|
2019-03-14 21:30:37 +01:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
GString *string;
|
|
|
|
gboolean export;
|
|
|
|
const gchar *name;
|
|
|
|
int layer;
|
|
|
|
GdkRGBA color;
|
|
|
|
|
|
|
|
string = g_string_new_len(NULL, max_len-1);
|
|
|
|
|
|
|
|
/* Extract values */
|
|
|
|
export = layer_element_get_export(layer_element);
|
|
|
|
name = (const gchar*)layer_element_get_name(layer_element);
|
|
|
|
layer = layer_element_get_layer(layer_element);
|
|
|
|
layer_element_get_color(layer_element, &color);
|
|
|
|
|
|
|
|
/* print values to line */
|
|
|
|
g_string_printf(string, "%d:%lf:%lf:%lf:%lf:%d:%s\n",
|
|
|
|
layer, color.red, color.green,
|
|
|
|
color.blue, color.alpha, (export == TRUE ? 1 : 0), name);
|
|
|
|
/* Fix broken locale settings */
|
|
|
|
for (i = 0; string->str[i]; i++) {
|
|
|
|
if (string->str[i] == ',')
|
|
|
|
string->str[i] = '.';
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; string->str[i]; i++) {
|
|
|
|
if (string->str[i] == ':')
|
|
|
|
string->str[i] = ',';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (string->len > (max_len-1)) {
|
|
|
|
printf("Layer Definition too long. Please shorten Layer Name!!\n");
|
|
|
|
line_buffer[0] = 0x0;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* copy max_len bytes of string */
|
|
|
|
strncpy(line_buffer, (char *)string->str, max_len-1);
|
|
|
|
line_buffer[max_len-1] = 0;
|
|
|
|
|
|
|
|
/* Completely remove string */
|
|
|
|
g_string_free(string, TRUE);
|
|
|
|
}
|
|
|
|
|
2018-07-24 17:45:16 +02:00
|
|
|
/** @} */
|
|
|
|
|