#include <plog.h>
#include <ppastats.h>
+static void arch_stats_free(struct arch_stats *arch)
+{
+ free(arch->name);
+ free(arch);
+}
+
+static struct distro_stats *distro_stats_new(const char *name)
+{
+ struct distro_stats *d;
+
+ d = malloc(sizeof(struct distro_stats));
+ d->name = strdup(name);
+ d->archs = NULL;
+ d->download_count = 0;
+ d->ddts = NULL;
+
+ return d;
+}
+
+static void distro_stats_free(struct distro_stats *distro)
+{
+ struct arch_stats **archs;
+
+ archs = distro->archs;
+ if (archs) {
+ while (*archs) {
+ arch_stats_free(*archs);
+ archs++;
+ }
+ free(distro->archs);
+ }
+
+ daily_download_total_list_free(distro->ddts);
+
+ free(distro->name);
+ free(distro);
+}
+
+static void distro_stats_list_free(struct distro_stats **distros)
+{
+ struct distro_stats **cur;
+
+ if (distros) {
+ cur = distros;
+ while (*cur) {
+ distro_stats_free(*cur);
+ cur++;
+ }
+ free(distros);
+ }
+}
+
+static void version_stats_free(struct version_stats *version)
+{
+ distro_stats_list_free(version->distros);
+ daily_download_total_list_free(version->daily_download_totals);
+
+ free(version->version);
+ free(version);
+}
+
+static void package_stats_free(struct package_stats *package)
+{
+ struct version_stats **versions;
+
+ versions = package->versions;
+ if (versions) {
+ while (*versions) {
+ version_stats_free(*versions);
+ versions++;
+ }
+ free(package->versions);
+ }
+ distro_stats_list_free(package->distros);
+ daily_download_total_list_free(package->daily_download_totals);
+ free(package->name);
+ free(package);
+}
+
+static struct package_stats *package_stats_new(const char *name)
+{
+ struct package_stats *p;
+
+ p = malloc(sizeof(struct package_stats));
+ p->name = strdup(name);
+ p->versions = NULL;
+ p->download_count = 0;
+ p->daily_download_totals = NULL;
+ p->distros = NULL;
+
+ return p;
+}
+
static struct package_stats *get_package_stats(struct ppa_stats *stats,
const char *name)
p_cur++;
}
- p = malloc(sizeof(struct package_stats));
- p->name = strdup(name);
- p->versions = NULL;
- p->download_count = 0;
- p->daily_download_totals = NULL;
- p->distros = NULL;
+ p = package_stats_new(name);
- tmp = (struct package_stats **)list_add
- ((void **)stats->packages, p);
+ tmp = (struct package_stats **)list_add((void **)stats->packages, p);
free(stats->packages);
stats->packages = tmp;
return p;
}
+static struct version_stats *version_stats_new(const char *version)
+{
+ struct version_stats *v;
+
+ v = malloc(sizeof(struct version_stats));
+ v->version = strdup(version);
+ v->distros = NULL;
+ v->download_count = 0;
+ v->daily_download_totals = NULL;
+ v->date_created = 0;
+
+ return v;
+}
+
static struct version_stats *get_version_stats(struct package_stats *package,
const char *version)
{
cur++;
}
- v = malloc(sizeof(struct version_stats));
- v->version = strdup(version);
- v->distros = NULL;
- v->download_count = 0;
- v->daily_download_totals = NULL;
+ v = version_stats_new(version);
tmp = (struct version_stats **)list_add((void **)package->versions,
v);
return v;
}
-static struct distro_stats *distro_stats_new(const char *name)
-{
- struct distro_stats *d;
-
- d = malloc(sizeof(struct distro_stats));
- d->name = strdup(name);
- d->archs = NULL;
- d->download_count = 0;
- d->ddts = NULL;
-
- return d;
-}
-
static struct distro_stats *get_distro_stats(struct version_stats *version,
const char *name)
{
d = distro_stats_new(name);
-
tmp = (struct distro_stats **)list_add((void **)version->distros,
- d);
+ d);
free(version->distros);
version->distros = tmp;
static struct arch_stats *get_arch_stats(struct distro_stats *distro,
const char *name)
{
- struct arch_stats **cur = distro->archs;
- struct arch_stats *a;
- struct arch_stats **tmp;
+ struct arch_stats **cur, *a, **tmp;
+ cur = distro->archs;
while (cur && *cur) {
a = *cur;
for (h_cur = history; *h_cur; ++h_cur) {
h = *h_cur;
- totals = get_daily_download_totals(h->self_link);
+ totals = get_daily_download_totals(h->self_link,
+ h->date_created);
if (!totals) {
log_err(_("Failed to retrieve download totals for %s"),
h->self_link);
pkg->daily_download_totals = tmp;
version = get_version_stats(pkg, pkg_version);
+ version->date_created = h->date_created;
+
version->download_count += count;
tmp = add_totals(version->daily_download_totals, totals);
if (version->daily_download_totals != tmp)
return ppa;
}
-static void arch_stats_free(struct arch_stats *arch)
-{
- free(arch->name);
- free(arch);
-}
-
-static void distro_stats_free(struct distro_stats *distro)
-{
- struct arch_stats **archs;
-
- archs = distro->archs;
- if (archs) {
- while (*archs) {
- arch_stats_free(*archs);
- archs++;
- }
- free(distro->archs);
- }
-
- daily_download_total_list_free(distro->ddts);
-
- free(distro->name);
- free(distro);
-}
-
-static void distro_stats_list_free(struct distro_stats **distros)
-{
- if (distros) {
- while (*distros) {
- distro_stats_free(*distros);
- distros++;
- }
- free(distros);
- }
-}
-
-static void version_stats_free(struct version_stats *version)
-{
- distro_stats_list_free(version->distros);
- daily_download_total_list_free(version->daily_download_totals);
-
- free(version->version);
- free(version);
-}
-
-static void package_stats_free(struct package_stats *package)
-{
- struct version_stats **versions;
-
- versions = package->versions;
- if (versions) {
- while (*versions) {
- version_stats_free(*versions);
- versions++;
- }
- free(package->versions);
- }
- distro_stats_list_free(package->distros);
- daily_download_total_list_free(package->daily_download_totals);
- free(package->name);
- free(package);
-}
-
void ppa_stats_free(struct ppa_stats *ppastats)
{
struct package_stats **packages;