diff options
author | Natanael Copa <ncopa@alpinelinux.org> | 2011-04-20 17:51:44 +0200 |
---|---|---|
committer | Natanael Copa <ncopa@alpinelinux.org> | 2011-04-20 17:51:44 +0200 |
commit | f372bfd978be3874c3361cc022e8fc5842657ad2 (patch) | |
tree | c058b1de64347d4e65e862a1f5f9124434240a24 /src/package.c | |
parent | fde9ad1782dd4ddb28c428b488e0278471a91c90 (diff) | |
parent | 35bba3de1f4d6464dc03ffc60b6a6b6ec25ef6b0 (diff) | |
download | apk-tools-lua.tar.bz2 apk-tools-lua.tar.xz |
Conflicts:
src/lua-apk.c
Diffstat (limited to 'src/package.c')
-rw-r--r-- | src/package.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/package.c b/src/package.c index 1a5d502..2699420 100644 --- a/src/package.c +++ b/src/package.c @@ -659,6 +659,18 @@ int apk_pkg_add_info(struct apk_database *db, struct apk_package *pkg, case 'i': apk_deps_parse(db, &pkg->install_if, value); break; + case 'o': + pkg->origin = apk_blob_atomize_dup(value); + break; + case 'm': + pkg->maintainer = apk_blob_atomize_dup(value); + break; + case 't': + pkg->build_time = apk_blob_pull_uint(&value, 10); + break; + case 'c': + pkg->commit = apk_blob_cstr(value); + break; case 'F': case 'M': case 'R': case 'Z': /* installed db entries which are handled in database.c */ return 1; @@ -691,6 +703,10 @@ static int read_info_line(void *ctx, apk_blob_t line) { "arch", 'A' }, { "depend", 'D' }, { "install_if", 'i' }, + { "origin", 'o' }, + { "maintainer", 'm' }, + { "builddate", 't' }, + { "commit", 'c' }, }; struct read_info_ctx *ri = (struct read_info_ctx *) ctx; apk_blob_t l, r; @@ -800,6 +816,8 @@ void apk_pkg_free(struct apk_package *pkg) free(pkg->url); if (pkg->description) free(pkg->description); + if (pkg->commit) + free(pkg->commit); free(pkg); } @@ -968,6 +986,22 @@ int apk_pkg_write_index_entry(struct apk_package *info, apk_blob_push_blob(&bbuf, APK_BLOB_STR(info->url)); apk_blob_push_blob(&bbuf, APK_BLOB_STR("\nL:")); apk_blob_push_blob(&bbuf, *info->license); + if (info->origin) { + apk_blob_push_blob(&bbuf, APK_BLOB_STR("\no:")); + apk_blob_push_blob(&bbuf, *info->origin); + } + if (info->maintainer) { + apk_blob_push_blob(&bbuf, APK_BLOB_STR("\nm:")); + apk_blob_push_blob(&bbuf, *info->maintainer); + } + if (info->build_time) { + apk_blob_push_blob(&bbuf, APK_BLOB_STR("\nt:")); + apk_blob_push_uint(&bbuf, info->build_time, 10); + } + if (info->commit) { + apk_blob_push_blob(&bbuf, APK_BLOB_STR("\nc:")); + apk_blob_push_blob(&bbuf, APK_BLOB_STR(info->commit)); + } apk_blob_push_blob(&bbuf, APK_BLOB_STR("\n")); if (APK_BLOB_IS_NULL(bbuf)) |