/** * mds — A micro-display server * Copyright © 2014 Mattias Andrée (maandree@member.fsf.org) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 this program. If not, see . */ #ifndef MDS_MDS_KBDC_RAW_DATA_H #define MDS_MDS_KBDC_RAW_DATA_H #include /** * Source code by lines, with and without comments */ typedef struct source_code { /** * Source code by lines without comments, * `NULL`-terminated. */ char** restrict lines; /** * Source code by lines with comments, * `NULL`-terminated. */ char** restrict real_lines; /** * Data for `lines` (internal data) */ char* content; /** * Data for `real_lines` (internal data) */ char* real_content; /** * The number of lines, that is, the number of * elements in `lines` and `real_lines`. */ size_t line_count; } source_code_t; /** * Initialise a `source_code_t*` * * @param this The `source_code_t*` */ void source_code_initialise(source_code_t* restrict this); /** * Release all data in a `source_code_t*` * * @param this The `source_code_t*` */ void source_code_destroy(source_code_t* restrict this); /** * Release all data in a `source_code_t*`, and free it * * @param this The `source_code_t*` */ void source_code_free(source_code_t* restrict this); /** * Read lines of a source file * * @param pathname The pathname of the source file * @param source_code Output parameter for read data * @return Zero on success, -1 on error */ int read_source_lines(const char* restrict pathname, source_code_t* restrict source_code); #endif