diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2015-06-21 07:12:19 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2015-06-21 10:47:00 -0700 |
commit | 97386a6f3d1667f293ab621fd8ae8a3ec2bf2ef2 (patch) | |
tree | cbb2a09ce757cc4444efd9ab46fea6f2df26cb37 | |
parent | 200572398920e418e548080ac1b4617a11f48270 (diff) | |
download | subsurface-97386a6f3d1667f293ab621fd8ae8a3ec2bf2ef2.tar.gz |
Git storage: store pictures in the repository
In order to be able to see pictures when using cloud storage from
different machines, we really need to store the pictures with the dive
data.
This could be made optional with a preference, but for now I'll just
enable it by default.
Loading the pictures from git still needs to be implemented.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | save-git.c | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/save-git.c b/save-git.c index f674b9d84..b7e519463 100644 --- a/save-git.c +++ b/save-git.c @@ -16,6 +16,7 @@ #include "membuffer.h" #include "git-access.h" #include "version.h" +#include "qthelperfromc.h" /* * handle libgit2 revision 0.20 and earlier @@ -556,6 +557,18 @@ static void create_dive_name(struct dive *dive, struct membuffer *name, struct t tm.tm_hour, tm.tm_min, tm.tm_sec); } +/* Write file at filepath to the git repo with given filename */ +static int blob_insert_fromdisk(git_repository *repo, struct dir *tree, const char *filepath, const char *filename) +{ + int ret; + git_oid blob_id; + + ret = git_blob_create_fromdisk(&blob_id, repo, filepath); + if (ret) + return ret; + return tree_insert(tree->files, filename, 1, &blob_id, GIT_FILEMODE_BLOB); +} + /* * Write a membuffer to the git repo, and free it */ @@ -594,6 +607,7 @@ static int save_one_picture(git_repository *repo, struct dir *dir, struct pictur struct membuffer buf = { 0 }; char sign = '+'; unsigned h; + int error; show_utf8(&buf, "filename ", pic->filename, "\n"); show_gps(&buf, pic->latitude, pic->longitude); @@ -608,8 +622,16 @@ static int save_one_picture(git_repository *repo, struct dir *dir, struct pictur /* Use full hh:mm:ss format to make it all sort nicely */ h = offset / 3600; offset -= h *3600; - return blob_insert(repo, dir, &buf, "%c%02u=%02u=%02u", + error = blob_insert(repo, dir, &buf, "%c%02u=%02u=%02u", sign, h, FRACTION(offset, 60)); + if (!error) { + /* next store the actual picture; we prefix all picture names + * with "PIC-" to make things easier on the parsing side */ + struct membuffer namebuf = { 0 }; + put_format(&namebuf, "PIC-%s", hashstring(pic->filename)); + error = blob_insert_fromdisk(repo, dir, pic->filename, mb_cstring(&namebuf)); + } + return error; } static int save_pictures(git_repository *repo, struct dir *dir, struct dive *dive) |