From cf68b09511481dbafcd625b8dec4603d4126599f Mon Sep 17 00:00:00 2001 From: jaortega Date: Wed, 20 Dec 2000 00:59:20 +0000 Subject: (mix_ins_to_string_in_buffer) new function --- mixlib/mix_ins.c | 26 ++++++++++++++++++++++++++ mixlib/mix_ins.h | 3 +++ 2 files changed, 29 insertions(+) diff --git a/mixlib/mix_ins.c b/mixlib/mix_ins.c index c5fcaf7..90ca15d 100644 --- a/mixlib/mix_ins.c +++ b/mixlib/mix_ins.c @@ -246,6 +246,32 @@ mix_ins_to_string(const mix_ins_t *ins) return result; } +extern void +mix_ins_to_string_in_buffer (const mix_ins_t *ins, gchar *buf, guint len) +{ + gboolean needs_f; + mix_ins_id_t id; + + g_return_if_fail (ins != NULL); + g_return_if_fail (buf != NULL); + id = mix_ins_id_from_ins(*ins); + needs_f = ins->fspec != id_to_desc_[id].def_fspec; + if ( needs_f ) + g_snprintf (buf, len, "%s\t%s%d,%d(%d:%d)", + mix_get_string_from_id(id), + mix_short_is_negative(ins->address)?"-":"", + mix_short_magnitude(ins->address), ins->index, + mix_fspec_left(ins->fspec), + mix_fspec_right(ins->fspec)); + else + g_snprintf(buf, len, "%s\t%s%d,%d", + mix_get_string_from_id(id), + mix_short_is_negative(ins->address)?"-":"", + mix_short_magnitude(ins->address), ins->index); +} + + + void mix_ins_print(const mix_ins_t *ins) { diff --git a/mixlib/mix_ins.h b/mixlib/mix_ins.h index d0829e5..065b342 100644 --- a/mixlib/mix_ins.h +++ b/mixlib/mix_ins.h @@ -172,6 +172,9 @@ mix_word_to_ins(mix_word_t w, mix_ins_t *ins); extern gchar * /* this pointer must be freed by caller */ mix_ins_to_string(const mix_ins_t *ins); +extern void +mix_ins_to_string_in_buffer (const mix_ins_t *ins, gchar *buf, guint len); + extern void mix_ins_print(const mix_ins_t *ins); -- cgit v1.2.3