Changeset 05816dd for protocols/msn


Ignore:
Timestamp:
2015-02-22T22:44:40Z (10 years ago)
Author:
dequis <dx@…>
Branches:
master
Children:
570f183
Parents:
91f06e5
git-author:
dequis <dx@…> (22-02-15 22:04:08)
git-committer:
dequis <dx@…> (22-02-15 22:44:40)
Message:

coverity: Fix some (harmless?) use-after-free with g_slist_remove()

These were passing a pointer to a variable right after it was g_free()'d

They are most likely harmless as g_slist_remove() probably just needs
the pointer location, but fixing it anyway.

Location:
protocols/msn
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • protocols/msn/msn.c

    r91f06e5 r05816dd  
    112112                while (md->groups) {
    113113                        struct msn_group *mg = md->groups->data;
     114                        md->groups = g_slist_remove(md->groups, mg);
    114115                        g_free(mg->id);
    115116                        g_free(mg->name);
    116117                        g_free(mg);
    117                         md->groups = g_slist_remove(md->groups, mg);
    118118                }
    119119
     
    127127                while (md->grpq) {
    128128                        struct msn_groupadd *ga = md->grpq->data;
     129                        md->grpq = g_slist_remove(md->grpq, ga);
    129130                        g_free(ga->group);
    130131                        g_free(ga->who);
    131132                        g_free(ga);
    132                         md->grpq = g_slist_remove(md->grpq, ga);
    133133                }
    134134
  • protocols/msn/ns.c

    r91f06e5 r05816dd  
    944944                struct msn_message *m = (*msgq)->data;
    945945
     946                *msgq = g_slist_remove(*msgq, m);
    946947                g_free(m->who);
    947948                g_free(m->text);
    948949                g_free(m);
    949 
    950                 *msgq = g_slist_remove(*msgq, m);
    951         }
    952 }
     950        }
     951}
  • protocols/msn/sb.c

    r91f06e5 r05816dd  
    519519                                        }
    520520                                }
     521                                sb->msgq = g_slist_remove(sb->msgq, m);
    521522                                g_free(m->text);
    522523                                g_free(m->who);
    523524                                g_free(m);
    524 
    525                                 sb->msgq = g_slist_remove(sb->msgq, m);
    526525                        }
    527526
Note: See TracChangeset for help on using the changeset viewer.