0

我有一个定义如下的函数(在 C 中):

gchar **Scan_Return_File_Tag_Field_From_Mask_Code (File_Tag *FileTag, gchar code)
{
    switch (code)
    {
        case 't':    /* Title */
            return &FileTag->title;
        case 'a':    /* Artist */
            return &FileTag->artist;
        case 'b':    /* Album */
            return &FileTag->album;
        case 'd':    /* Disc Number */
            return &FileTag->disc_number;
        case 'y':    /* Year */
            return &FileTag->year;
        case 'n':    /* Track */
            return &FileTag->track;
        case 'l':    /* Track Total */
            return &FileTag->track_total;
        case 'g':    /* Genre */
            return &FileTag->genre;
        case 'c':    /* Comment */
            return &FileTag->comment;
        case 'p':    /* Composer */
            return &FileTag->composer;
        case 'o':    /* Orig. Artist */
            return &FileTag->orig_artist;
        case 'r':    /* Copyright */
            return &FileTag->copyright;
        case 'u':    /* URL */
            return &FileTag->url;
        case 'e':    /* Encoded by */
            return &FileTag->encoded_by;
        case 'i':    /* Ignored */
            return NULL;
        default:
            Log_Print(LOG_ERROR,"Scanner: Invalid code '%%%c' found!",code);
            return NULL;
    }
}

我正在尝试向 switch 语句添加一个新条件,例如

case 'f':

它将返回 &FileTag->artist 的第一个字符。

我已经搜索了所有互联网寻找解决方案,但空手而归。有人有想法么?

更新: 如果有帮助,此功能是应用程序 EasyTag 的一部分。从我看到的代码来看,这是确定easytag文件排序功能的新文件名的地方。我正在尝试添加一个新变量以允许应用程序将音乐排序到如下目录中:<First letter of artist name>/<Artist>/<Album>/<Tracks>

我总是有可能正在查看错误的功能,但据我所知,我是。

另一个更新: 我让这个函数按我的意愿工作(指针是有趣的小东西),但它并没有像下面指出的那样做我所期望的。感谢所有的帮助和耐心!

4

4 回答 4

1

我不太确定为什么您的代码会返回指向指针的指针,但这会使您所需的操作更加困难。由于您需要返回指针的地址,而不仅仅是指针本身,因此您必须在某处分配该新指针(然后谁来释放它?)。如果你不介意内存泄漏,你可以忽略这个问题,只分配一个指针并返回它的地址。或者,您可以创建一个新成员,File_Tag该成员包含一个包含 的第一个字符的短字符串artist

glib 字符串函数将对此有所帮助,快速浏览列表显示g_strdup_printf()可能会很有用:

gchar *first = g_strdup_printf("%c", FileTag->artist[0]);

然后分配某个地方来存储first并返回该地址。

更新:使用http://codesearch.google.com,我似乎找到了您要更改的函数的使用位置,看起来返回值用于更改返回的字段。

    // Get the target entry for this code
    dest = Scan_Return_File_Tag_Field_From_Mask_Code(FileTag,mask_item->code);

    // We display the text affected to the code
    if ( dest && ( OVERWRITE_TAG_FIELD || *dest==NULL || strlen(*dest)==0 ) )
        ET_Set_Field_File_Tag_Item(dest,mask_item->string);

如果您的代码返回一个包含艺术家姓名第一个字符的新字符串,我不确定您到底想做什么。上面的代码会改变你新分配的字符串指向的内容,这对实际的艺术家姓名没有影响。

于 2009-11-26T18:54:31.797 回答
1

如果目标是返回一个指向仅包含第一个字母的字符串的指针并且您不关心线程安全,那么以下应该可以工作

static char buf[2];
static char *pbuf = buf;
...
case 'f':
    buf[0] = FileTag->artist[0];
    return &pbuf;

但是,我觉得奇怪的是,您返回的是指向“char”指针的指针,而不仅仅是指向“char”的指针。

于 2009-11-26T19:01:57.850 回答
0

不要搜索互联网。自己编码。添加这个:

        case 'f':    /* Artist */
            return &FileTag->artist;

假设&FileTag->artist是 type gchar **

于 2009-11-26T18:51:36.283 回答
0

如果可能的话,我会得到整个艺术家字符串,然后简单地从你调用函数的任何地方访问第一个字母:

gchar **artist = Scan_Return_File_Tag_Field_From_Mask_Code (File_Tag *FileTag, 'f')
printf("%c", *artist[0]);

如果这不是一个选项,你可以为你的角色分配新的内存,但这相当棘手,因为你想返回一个指向指针的指针。因此,您还必须为该指针分配内存。也许你可以改变它...

于 2009-11-26T18:59:40.510 回答