2012-05-03 20:16:37 -04:00
|
|
|
/*
|
|
|
|
* contact.c
|
|
|
|
*
|
|
|
|
* Copyright (C) 2012 James Booth <boothj5@gmail.com>
|
|
|
|
*
|
|
|
|
* This file is part of Profanity.
|
|
|
|
*
|
|
|
|
* Profanity is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Profanity is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with Profanity. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2012-05-03 20:00:01 -04:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "contact.h"
|
|
|
|
|
|
|
|
struct p_contact_t {
|
|
|
|
char *name;
|
|
|
|
char *show;
|
|
|
|
char *status;
|
|
|
|
};
|
|
|
|
|
|
|
|
PContact p_contact_new(const char * const name, const char * const show,
|
|
|
|
const char * const status)
|
|
|
|
{
|
|
|
|
PContact contact = malloc(sizeof(struct p_contact_t));
|
|
|
|
contact->name = strdup(name);
|
|
|
|
|
|
|
|
if (show == NULL || (strcmp(show, "") == 0))
|
|
|
|
contact->show = strdup("online");
|
|
|
|
else
|
|
|
|
contact->show = strdup(show);
|
|
|
|
|
|
|
|
if (status != NULL)
|
|
|
|
contact->status = strdup(status);
|
|
|
|
else
|
|
|
|
contact->status = NULL;
|
|
|
|
|
|
|
|
return contact;
|
|
|
|
}
|
|
|
|
|
2012-05-17 20:33:40 -04:00
|
|
|
PContact p_contact_copy(PContact contact)
|
|
|
|
{
|
|
|
|
PContact copy = malloc(sizeof(struct p_contact_t));
|
|
|
|
copy->name = strdup(contact->name);
|
|
|
|
copy->show = strdup(contact->show);
|
|
|
|
|
|
|
|
if (contact->status != NULL)
|
|
|
|
copy->status = strdup(contact->status);
|
|
|
|
else
|
|
|
|
copy->status = NULL;
|
|
|
|
|
|
|
|
return copy;
|
|
|
|
}
|
|
|
|
|
2012-05-03 20:00:01 -04:00
|
|
|
void p_contact_free(PContact contact)
|
|
|
|
{
|
|
|
|
free(contact->name);
|
|
|
|
|
|
|
|
if (contact->show != NULL) {
|
|
|
|
free(contact->show);
|
|
|
|
contact->show = NULL;
|
|
|
|
}
|
|
|
|
if (contact->status != NULL) {
|
|
|
|
free(contact->status);
|
|
|
|
contact->status = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
free(contact);
|
|
|
|
contact = NULL;
|
|
|
|
}
|
|
|
|
|
2012-05-09 18:22:48 -04:00
|
|
|
const char * p_contact_name(const PContact contact)
|
2012-05-03 20:00:01 -04:00
|
|
|
{
|
|
|
|
return contact->name;
|
|
|
|
}
|
|
|
|
|
2012-05-09 18:22:48 -04:00
|
|
|
const char * p_contact_show(const PContact contact)
|
2012-05-03 20:00:01 -04:00
|
|
|
{
|
|
|
|
return contact->show;
|
|
|
|
}
|
|
|
|
|
2012-05-09 18:22:48 -04:00
|
|
|
const char * p_contact_status(const PContact contact)
|
2012-05-03 20:00:01 -04:00
|
|
|
{
|
|
|
|
return contact->status;
|
|
|
|
}
|
2012-05-23 18:53:10 -04:00
|
|
|
|
|
|
|
int p_contact_names_equal(const PContact c1, const PContact c2)
|
|
|
|
{
|
|
|
|
return strcmp(c1->name, c2->name);
|
|
|
|
}
|
|
|
|
|
|
|
|
int p_contacts_equal_deep(const PContact c1, const PContact c2)
|
|
|
|
{
|
|
|
|
int name_eq = strcmp(c1->name, c2->name);
|
|
|
|
int show_eq = strcmp(c1->show, c2->show);
|
|
|
|
int status_eq = strcmp(c1->status, c2->status);
|
|
|
|
|
|
|
|
return (name_eq && show_eq && status_eq);
|
|
|
|
}
|