2017-04-27 20:18:03 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2012-01-27 12:43:40 -08:00
|
|
|
#ifndef FILE_H
|
|
|
|
#define FILE_H
|
|
|
|
|
2020-06-17 22:45:33 +02:00
|
|
|
#include "filterpreset.h"
|
|
|
|
|
2019-08-05 20:07:10 +02:00
|
|
|
#include <sys/stat.h>
|
2020-05-01 13:43:52 +02:00
|
|
|
#include <stdio.h>
|
2024-05-04 17:55:50 +02:00
|
|
|
#include <vector>
|
|
|
|
#include <utility>
|
2019-08-05 20:07:10 +02:00
|
|
|
|
core: introduce divelog structure
The parser API was very annoying, as a number of tables
to-be-filled were passed in as pointers. The goal of this
commit is to collect all these tables in a single struct.
This should make it (more or less) clear what is actually
written into the divelog files.
Moreover, it should now be rather easy to search for
instances, where the global logfile is accessed (and it
turns out that there are many!).
The divelog struct does not contain the tables as substructs,
but only collects pointers. The idea is that the "divelog.h"
file can be included without all the other files describing
the numerous tables.
To make it easier to use from C++ parts of the code, the
struct implements a constructor and a destructor. Sadly,
we can't use smart pointers, since the pointers are accessed
from C code. Therfore the constructor and destructor are
quite complex.
The whole commit is large, but was mostly an automatic
conversion.
One oddity of note: the divelog structure also contains
the "autogroup" flag, since that is saved in the divelog.
This actually fixes a bug: Before, when importing dives
from a different log, the autogroup flag was overwritten.
This was probably not intended and does not happen anymore.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2022-11-08 21:31:08 +01:00
|
|
|
struct divelog;
|
2019-08-05 20:07:10 +02:00
|
|
|
struct zip;
|
2019-08-05 19:41:15 +02:00
|
|
|
|
core: introduce divelog structure
The parser API was very annoying, as a number of tables
to-be-filled were passed in as pointers. The goal of this
commit is to collect all these tables in a single struct.
This should make it (more or less) clear what is actually
written into the divelog files.
Moreover, it should now be rather easy to search for
instances, where the global logfile is accessed (and it
turns out that there are many!).
The divelog struct does not contain the tables as substructs,
but only collects pointers. The idea is that the "divelog.h"
file can be included without all the other files describing
the numerous tables.
To make it easier to use from C++ parts of the code, the
struct implements a constructor and a destructor. Sadly,
we can't use smart pointers, since the pointers are accessed
from C code. Therfore the constructor and destructor are
quite complex.
The whole commit is large, but was mostly an automatic
conversion.
One oddity of note: the divelog structure also contains
the "autogroup" flag, since that is saved in the divelog.
This actually fixes a bug: Before, when importing dives
from a different log, the autogroup flag was overwritten.
This was probably not intended and does not happen anymore.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2022-11-08 21:31:08 +01:00
|
|
|
extern void ostctools_import(const char *file, struct divelog *log);
|
2014-01-27 14:44:26 +01:00
|
|
|
|
core: introduce divelog structure
The parser API was very annoying, as a number of tables
to-be-filled were passed in as pointers. The goal of this
commit is to collect all these tables in a single struct.
This should make it (more or less) clear what is actually
written into the divelog files.
Moreover, it should now be rather easy to search for
instances, where the global logfile is accessed (and it
turns out that there are many!).
The divelog struct does not contain the tables as substructs,
but only collects pointers. The idea is that the "divelog.h"
file can be included without all the other files describing
the numerous tables.
To make it easier to use from C++ parts of the code, the
struct implements a constructor and a destructor. Sadly,
we can't use smart pointers, since the pointers are accessed
from C code. Therfore the constructor and destructor are
quite complex.
The whole commit is large, but was mostly an automatic
conversion.
One oddity of note: the divelog structure also contains
the "autogroup" flag, since that is saved in the divelog.
This actually fixes a bug: Before, when importing dives
from a different log, the autogroup flag was overwritten.
This was probably not intended and does not happen anymore.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2022-11-08 21:31:08 +01:00
|
|
|
extern int parse_file(const char *filename, struct divelog *log);
|
|
|
|
extern int try_to_open_zip(const char *filename, struct divelog *log);
|
2019-08-05 20:07:10 +02:00
|
|
|
|
|
|
|
// Platform specific functions
|
|
|
|
extern int subsurface_rename(const char *path, const char *newpath);
|
|
|
|
extern int subsurface_dir_rename(const char *path, const char *newpath);
|
|
|
|
extern int subsurface_open(const char *path, int oflags, mode_t mode);
|
|
|
|
extern FILE *subsurface_fopen(const char *path, const char *mode);
|
|
|
|
extern void *subsurface_opendir(const char *path);
|
|
|
|
extern int subsurface_access(const char *path, int mode);
|
core: introduce divelog structure
The parser API was very annoying, as a number of tables
to-be-filled were passed in as pointers. The goal of this
commit is to collect all these tables in a single struct.
This should make it (more or less) clear what is actually
written into the divelog files.
Moreover, it should now be rather easy to search for
instances, where the global logfile is accessed (and it
turns out that there are many!).
The divelog struct does not contain the tables as substructs,
but only collects pointers. The idea is that the "divelog.h"
file can be included without all the other files describing
the numerous tables.
To make it easier to use from C++ parts of the code, the
struct implements a constructor and a destructor. Sadly,
we can't use smart pointers, since the pointers are accessed
from C code. Therfore the constructor and destructor are
quite complex.
The whole commit is large, but was mostly an automatic
conversion.
One oddity of note: the divelog structure also contains
the "autogroup" flag, since that is saved in the divelog.
This actually fixes a bug: Before, when importing dives
from a different log, the autogroup flag was overwritten.
This was probably not intended and does not happen anymore.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2022-11-08 21:31:08 +01:00
|
|
|
extern int subsurface_stat(const char *path, struct stat *buf);
|
2019-08-05 20:07:10 +02:00
|
|
|
extern struct zip *subsurface_zip_open_readonly(const char *path, int flags, int *errorp);
|
|
|
|
extern int subsurface_zip_close(struct zip *zip);
|
2024-05-04 18:45:55 +02:00
|
|
|
extern std::pair<std::string, int> readfile(const char *filename); // return data, errorcode pair.
|
2024-03-01 13:09:20 +01:00
|
|
|
extern int try_to_open_cochran(const char *filename, std::string &mem, struct divelog *log);
|
|
|
|
extern int try_to_open_liquivision(const char *filename, std::string &mem, struct divelog *log);
|
|
|
|
extern int datatrak_import(std::string &mem, std::string &wl_mem, struct divelog *log);
|
|
|
|
|
2014-02-11 19:14:46 +01:00
|
|
|
#endif // FILE_H
|