From 30cce8f1904a4b593c4d0a0f0181572bed06e5b6 Mon Sep 17 00:00:00 2001 From: Thierry Vignaud Date: Thu, 22 Apr 2004 06:34:56 +0000 Subject: (return_list_tag) factorize common local variables declaration (though it wastes 4 pointer slots on stack in RPMTAG_SUMMARY case) --- URPM.xs | 25 +++++-------------------- 1 file changed, 5 insertions(+), 20 deletions(-) diff --git a/URPM.xs b/URPM.xs index 3e84100..51734da 100644 --- a/URPM.xs +++ b/URPM.xs @@ -745,47 +745,32 @@ return_list_tag(URPM__Package pkg, int_32 tag_name) { } } } else { + char *name; + char *version; + char *release; + char *arch; + char *eos; switch (tag_name) { case RPMTAG_NAME: { - char *name; - char *version; - char *release; - char *arch; - char *eos; get_fullname_parts(pkg, &name, &version, &release, &arch, &eos); XPUSHs(sv_2mortal(newSVpv(name, version-name))); } break; case RPMTAG_VERSION: { - char *name; - char *version; - char *release; - char *arch; - char *eos; get_fullname_parts(pkg, &name, &version, &release, &arch, &eos); XPUSHs(sv_2mortal(newSVpv(version, release-version))); } break; case RPMTAG_RELEASE: { - char *name; - char *version; - char *release; - char *arch; - char *eos; get_fullname_parts(pkg, &name, &version, &release, &arch, &eos); XPUSHs(sv_2mortal(newSVpv(release, arch-release))); } break; case RPMTAG_ARCH: { - char *name; - char *version; - char *release; - char *arch; - char *eos; get_fullname_parts(pkg, &name, &version, &release, &arch, &eos); XPUSHs(sv_2mortal(newSVpv(arch, eos-arch))); } -- cgit v1.2.1