Code Review
/
src
/
app-framework-main.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
review
|
tree
raw
|
inline
| side by side
Add ability to manage all widget/applications
[src/app-framework-main.git]
/
src
/
wgtpkg-zip.c
diff --git
a/src/wgtpkg-zip.c
b/src/wgtpkg-zip.c
index
f7813c4
..
ec214b1
100644
(file)
--- a/
src/wgtpkg-zip.c
+++ b/
src/wgtpkg-zip.c
@@
-1,5
+1,5
@@
/*
/*
- Copyright
2015
IoT.bzh
+ Copyright
(C) 2015-2018
IoT.bzh
author: José Bollo <jose.bollo@iot.bzh>
author: José Bollo <jose.bollo@iot.bzh>
@@
-33,8
+33,8
@@
#include "wgtpkg-workdir.h"
#include "wgtpkg-zip.h"
#include "wgtpkg-workdir.h"
#include "wgtpkg-zip.h"
-#define MODE_OF_FILE_CREATION 064
0
-#define MODE_OF_DIRECTORY_CREATION 075
0
+#define MODE_OF_FILE_CREATION 064
4
+#define MODE_OF_DIRECTORY_CREATION 075
5
#if !defined(USE_LIBZIP)
# define USE_LIBZIP 1
#if !defined(USE_LIBZIP)
# define USE_LIBZIP 1
@@
-68,7
+68,7
@@
static int is_valid_filename(const char *filename)
return !lastsp;
}
return !lastsp;
}
-static int create_directory(char *file,
in
t mode)
+static int create_directory(char *file,
mode_
t mode)
{
int rc;
char *last = strrchr(file, '/');
{
int rc;
char *last = strrchr(file, '/');
@@
-91,7
+91,7
@@
static int create_directory(char *file, int mode)
return rc;
}
return rc;
}
-static int create_file(char *file, int fmode,
in
t dmode)
+static int create_file(char *file, int fmode,
mode_
t dmode)
{
int fd = openat(workdirfd, file, O_CREAT|O_WRONLY|O_TRUNC, fmode);
if (fd < 0 && errno == ENOENT) {
{
int fd = openat(workdirfd, file, O_CREAT|O_WRONLY|O_TRUNC, fmode);
if (fd < 0 && errno == ENOENT) {
@@
-107,15
+107,17
@@
static int create_file(char *file, int fmode, int dmode)
int zread(const char *zipfile, unsigned long long maxsize)
{
struct filedesc *fdesc;
int zread(const char *zipfile, unsigned long long maxsize)
{
struct filedesc *fdesc;
- int err, fd, len;
+ int err, fd;
+ size_t len;
struct zip *zip;
zip_int64_t z64;
struct zip *zip;
zip_int64_t z64;
+ zip_uint64_t uz64;
unsigned int count, index;
struct zip_file *zfile;
struct zip_stat zstat;
char buffer[32768];
ssize_t sizr, sizw;
unsigned int count, index;
struct zip_file *zfile;
struct zip_stat zstat;
char buffer[32768];
ssize_t sizr, sizw;
-
size
_t esize;
+
zip_uint64
_t esize;
/* open the zip file */
zip = zip_open(zipfile, ZIP_CHECKCONS, &err);
/* open the zip file */
zip = zip_open(zipfile, ZIP_CHECKCONS, &err);
@@
-195,19
+197,19
@@
int zread(const char *zipfile, unsigned long long maxsize)
if (fd < 0)
goto errorz;
/* extract */
if (fd < 0)
goto errorz;
/* extract */
- z64 = zstat.size;
- while (z64) {
- sizr = zip_fread(zfile, buffer, sizeof buffer);
+
u
z64 = zstat.size;
+ while (
u
z64) {
+ sizr =
(ssize_t)
zip_fread(zfile, buffer, sizeof buffer);
if (sizr < 0) {
ERROR("error while reading %s in %s", zstat.name, zipfile);
goto errorzf;
}
if (sizr < 0) {
ERROR("error while reading %s in %s", zstat.name, zipfile);
goto errorzf;
}
- sizw = write(fd, buffer, sizr);
+ sizw = write(fd, buffer,
(size_t)
sizr);
if (sizw < 0) {
ERROR("error while writing %s", zstat.name);
goto errorzf;
}
if (sizw < 0) {
ERROR("error while writing %s", zstat.name);
goto errorzf;
}
-
z64 -=
sizw;
+
uz64 -= (size_t)
sizw;
}
close(fd);
zip_fclose(zfile);
}
close(fd);
zip_fclose(zfile);
@@
-232,24
+234,26
@@
struct zws {
char buffer[32768];
};
char buffer[32768];
};
-static int zwr(struct zws *zws,
in
t offset)
+static int zwr(struct zws *zws,
size_
t offset)
{
{
- int len, err, fd;
+ int err, fd;
+ size_t len;
DIR *dir;
struct dirent *ent;
zip_int64_t z64;
struct zip_source *zsrc;
FILE *fp;
DIR *dir;
struct dirent *ent;
zip_int64_t z64;
struct zip_source *zsrc;
FILE *fp;
+ struct stat st;
fd = openat(workdirfd, offset ? zws->name : ".", O_DIRECTORY|O_RDONLY);
if (fd < 0) {
fd = openat(workdirfd, offset ? zws->name : ".", O_DIRECTORY|O_RDONLY);
if (fd < 0) {
- ERROR("opendir %.*s failed in zwr", offset, zws->name);
+ ERROR("opendir %.*s failed in zwr",
(int)
offset, zws->name);
return -1;
}
dir = fdopendir(fd);
if (!dir) {
close(fd);
return -1;
}
dir = fdopendir(fd);
if (!dir) {
close(fd);
- ERROR("opendir %.*s failed in zwr", offset, zws->name);
+ ERROR("opendir %.*s failed in zwr",
(int)
offset, zws->name);
return -1;
}
return -1;
}
@@
-272,6
+276,13
@@
static int zwr(struct zws *zws, int offset)
ERROR("invalid name %s", zws->name);
goto error;
}
ERROR("invalid name %s", zws->name);
goto error;
}
+ if (ent->d_type == DT_UNKNOWN) {
+ fstatat(fd, ent->d_name, &st, 0);
+ if (S_ISREG(st.st_mode))
+ ent->d_type = DT_REG;
+ else if (S_ISDIR(st.st_mode))
+ ent->d_type = DT_DIR;
+ }
switch (ent->d_type) {
case DT_DIR:
z64 = zip_dir_add(zws->zip, zws->name, ZIP_FL_ENC_UTF_8);
switch (ent->d_type) {
case DT_DIR:
z64 = zip_dir_add(zws->zip, zws->name, ZIP_FL_ENC_UTF_8);