#include <json/json.h>
#include "html.h"
+#include "io.h"
#include "lp.h"
#include "lp_ws.h"
#include "ppastats.h"
-enum file_copy_error {
- FILE_COPY_ERROR_OPEN_SRC = 1,
- FILE_COPY_ERROR_OPEN_DST,
- FILE_COPY_ERROR_READ,
- FILE_COPY_ERROR_WRITE,
- FILE_COPY_ERROR_ALLOC_BUFFER
-};
-
#define HTML_FOOTER \
" <div id=\"footer\">Generated by \
<a href='http://wpitchoune.net/ppastats'>ppastats</a></div>\n\
<a href=\"index.html\">\n\
<span id=\"ppa_owner\">N/A</span>/<span id=\"ppa_name\">N/A</span>\n\
</a></p>\n\
- <div id=\"chart\"></div>\n\
- <div id=\"versions\"><em>Versions:</em></div>\n\
+ <div id=\"charts\">\n\
+ <div id=\"chart\"></div>\n\
+ <div id=\"chart_distro\"></div>\n\
+ </div>\n\
+ <div id=\"details\">\n\
+ <div id=\"versions\"><em>Versions:</em></div>\n\
+ <div id=\"distros\"><em>Distros:</em></div>\n\
+ </div>\n\
%s"
#define HTML_VERSION_TEMPLATE \
<a href=\"index.html\">\n\
<span id=\"ppa_owner\">N/A</span>/<span id=\"ppa_name\">N/A</span>\n\
</a></p>\n\
- <div id=\"chart\"></div>\n\
- <div class=\"distros\">\n\
- <em>Distros</em>:\n\
- <ul id=\"distros\"></ul>\n\
+ <div id=\"charts\">\n\
+ <div id=\"chart\"></div>\n\
+ </div>\n\
+ <div id=\"details\">\n\
+ <div class=\"distros\">\n\
+ <em>Distros</em>:\n\
+ <ul id=\"distros\"></ul>\n\
+ </div>\n\
</div>\n\
%s"
</head>\n\
<body>\n\
<h1><span id=\"ppa_name\">N/A</span></h1>\n\
- <div class=\"pkgs\">\n\
- <em>Packages</em>:\n\
- <ul id=\"pkgs\"></ul>\n\
+ <div id=\"details\">\n\
+ <div class=\"pkgs\">\n\
+ <em>Packages</em>:\n\
+ <ul id=\"pkgs\"></ul>\n\
+ </div>\n\
+ </div>\n\
+ <div id=\"charts\">\n\
+ <div id=\"chart\"></div>\n\
</div>\n\
- <div id=\"chart\"></div>\n\
%s"
-#define FCOPY_BUF_SZ 4096
-static int file_copy(FILE * src, FILE * dst)
-{
- int ret = 0;
- char *buf = malloc(FCOPY_BUF_SZ);
- int n;
-
- if (!buf)
- return FILE_COPY_ERROR_ALLOC_BUFFER;
-
- while (!ret) {
- n = fread(buf, 1, FCOPY_BUF_SZ, src);
- if (n) {
- if (fwrite(buf, 1, n, dst) != n)
- ret = FILE_COPY_ERROR_WRITE;
- } else {
- if (!feof(src))
- ret = FILE_COPY_ERROR_READ;
- else
- break;
- }
- }
-
- free(buf);
-
- return ret;
-}
-
-int
-fcopy(const char *src, const char *dst)
-{
- FILE *fsrc, *fdst;
- int ret = 0;
-
- if (debug)
- printf("DEBUG: copy: %s to %s\n", src, dst);
-
- fsrc = fopen(src, "r");
-
- if (fsrc) {
- fdst = fopen(dst, "w+");
-
- if (fdst) {
- ret = file_copy(fsrc, fdst);
- fclose(fdst);
- } else {
- ret = FILE_COPY_ERROR_OPEN_DST;
- }
-
- fclose(fsrc);
- } else {
- ret = FILE_COPY_ERROR_OPEN_SRC;
- }
-
- return ret;
-}
-
-static char *get_path(const char *dir, const char *file)
+static char *path_new(const char *dir, const char *file, const char *suffixe)
{
char *path = malloc(strlen(dir)+1+
strlen(file)+
strlen(".html")+
+ (suffixe ? strlen(suffixe) : 0) +
1);
strcpy(path, dir);
static char *pkg_to_json(struct ppa_stats *ppa, struct package_stats *pkg)
{
- json_object *json, *json_versions;
+ json_object *json, *json_versions, *json_distros, *json_distro;
char *ret;
struct version_stats **versions;
+ struct distro_stats **distros, *distro;
json = json_object_new_object();
versions++;
}
+ distros = pkg->distros;
+ if (distros) {
+ json_distros = json_object_new_array();
+ json_object_object_add(json, "distros", json_distros);
+
+ while (*distros) {
+ distro = *distros;
+
+ json_distro = json_object_new_object();
+ json_object_array_add(json_distros, json_distro);
+ json_object_object_add
+ (json_distro,
+ "name", json_object_new_string(distro->name));
+ json_object_object_add
+ (json_distro,
+ "count",
+ json_object_new_int(distro->download_count));
+
+ json_add_ddts(json_distro, distro->ddts);
+
+ distros++;
+ }
+ }
+
json_add_ddts(json, pkg->daily_download_totals);
ret = strdup(json_object_to_json_string(json));
FILE *f;
char *json;
- path = get_path(dir, pkg->name);
+ path = path_new(dir, pkg->name, ".html");
f = fopen(path, "w");
if (!f) {
f_name = malloc(strlen(pkg->name)+1+strlen(version->version)+1);
sprintf(f_name, "%s_%s", pkg->name, version->version);
- path = get_path(dir, f_name);
+ path = path_new(dir, f_name, ".html");
f = fopen(path, "w");
if (!f) {
char *path;
FILE *f;
- path = get_path(dir, "index");
+ path = path_new(dir, "index", ".html");
f = fopen(path, "w");
if (!f) {
ppastats = create_ppa_stats(owner, ppa, package_status);
totals = ppastats->daily_download_totals;
- path = get_path(output_dir, "ppa");
+ path = path_new(output_dir, "ppa", ".html");
packages_to_html(ppastats, ppastats->packages, output_dir);