mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Move subsurface-core to core and qt-mobile to mobile-widgets
Having subsurface-core as a directory name really messes with autocomplete and is obviously redundant. Simmilarly, qt-mobile caused an autocomplete conflict and also was inconsistent with the desktop-widget name for the directory containing the "other" UI. And while cleaning up the resulting change in the path name for include files, I decided to clean up those even more to make them consistent overall. This could have been handled in more commits, but since this requires a make clean before the build, it seemed more sensible to do it all in one. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
2d760a7bff
commit
7be962bfc2
254 changed files with 572 additions and 582 deletions
74
core/membuffer.h
Normal file
74
core/membuffer.h
Normal file
|
|
@ -0,0 +1,74 @@
|
|||
#ifndef MEMBUFFER_H
|
||||
#define MEMBUFFER_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <ctype.h>
|
||||
|
||||
struct membuffer {
|
||||
unsigned int len, alloc;
|
||||
char *buffer;
|
||||
};
|
||||
|
||||
#ifdef __GNUC__
|
||||
#define __printf(x, y) __attribute__((__format__(__printf__, x, y)))
|
||||
#else
|
||||
#define __printf(x, y)
|
||||
#endif
|
||||
|
||||
extern char *detach_buffer(struct membuffer *b);
|
||||
extern void free_buffer(struct membuffer *);
|
||||
extern void flush_buffer(struct membuffer *, FILE *);
|
||||
extern void put_bytes(struct membuffer *, const char *, int);
|
||||
extern void put_string(struct membuffer *, const char *);
|
||||
extern void put_quoted(struct membuffer *, const char *, int, int);
|
||||
extern void strip_mb(struct membuffer *);
|
||||
extern const char *mb_cstring(struct membuffer *);
|
||||
extern __printf(2, 0) void put_vformat(struct membuffer *, const char *, va_list);
|
||||
extern __printf(2, 3) void put_format(struct membuffer *, const char *fmt, ...);
|
||||
extern __printf(2, 0) char *add_to_string_va(const char *old, const char *fmt, va_list args);
|
||||
extern __printf(2, 3) char *add_to_string(const char *old, const char *fmt, ...);
|
||||
|
||||
/* Helpers that use membuffers internally */
|
||||
extern __printf(1, 0) char *vformat_string(const char *, va_list);
|
||||
extern __printf(1, 2) char *format_string(const char *, ...);
|
||||
|
||||
|
||||
/* Output one of our "milli" values with type and pre/post data */
|
||||
extern void put_milli(struct membuffer *, const char *, int, const char *);
|
||||
|
||||
/*
|
||||
* Helper functions for showing particular types. If the type
|
||||
* is empty, nothing is done, and the function returns false.
|
||||
* Otherwise, it returns true.
|
||||
*
|
||||
* The two "const char *" at the end are pre/post data.
|
||||
*
|
||||
* The reason for the pre/post data is so that you can easily
|
||||
* prepend and append a string without having to test whether the
|
||||
* type is empty. So
|
||||
*
|
||||
* put_temperature(b, temp, "Temp=", " C\n");
|
||||
*
|
||||
* writes nothing to the buffer if there is no temperature data,
|
||||
* but otherwise would a string that looks something like
|
||||
*
|
||||
* "Temp=28.1 C\n"
|
||||
*
|
||||
* to the memory buffer (typically the post/pre will be some XML
|
||||
* pattern and unit string or whatever).
|
||||
*/
|
||||
extern void put_temperature(struct membuffer *, temperature_t, const char *, const char *);
|
||||
extern void put_depth(struct membuffer *, depth_t, const char *, const char *);
|
||||
extern void put_duration(struct membuffer *, duration_t, const char *, const char *);
|
||||
extern void put_pressure(struct membuffer *, pressure_t, const char *, const char *);
|
||||
extern void put_salinity(struct membuffer *, int, const char *, const char *);
|
||||
extern void put_degrees(struct membuffer *b, degrees_t value, const char *, const char *);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
Loading…
Add table
Add a link
Reference in a new issue