Let the GSMCommand class have its own file
This commit is contained in:
parent
0f84098442
commit
f0e4d57e23
2
Makefile
2
Makefile
@ -37,6 +37,7 @@ dist:
|
|||||||
$(PACKAGE)-$(VERSION)/po/fr.po \
|
$(PACKAGE)-$(VERSION)/po/fr.po \
|
||||||
$(PACKAGE)-$(VERSION)/po/project.conf \
|
$(PACKAGE)-$(VERSION)/po/project.conf \
|
||||||
$(PACKAGE)-$(VERSION)/src/callbacks.c \
|
$(PACKAGE)-$(VERSION)/src/callbacks.c \
|
||||||
|
$(PACKAGE)-$(VERSION)/src/command.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/gsm.c \
|
$(PACKAGE)-$(VERSION)/src/gsm.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/main.c \
|
$(PACKAGE)-$(VERSION)/src/main.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/phone.c \
|
$(PACKAGE)-$(VERSION)/src/phone.c \
|
||||||
@ -45,6 +46,7 @@ dist:
|
|||||||
$(PACKAGE)-$(VERSION)/src/messages.c \
|
$(PACKAGE)-$(VERSION)/src/messages.c \
|
||||||
$(PACKAGE)-$(VERSION)/src/Makefile \
|
$(PACKAGE)-$(VERSION)/src/Makefile \
|
||||||
$(PACKAGE)-$(VERSION)/src/callbacks.h \
|
$(PACKAGE)-$(VERSION)/src/callbacks.h \
|
||||||
|
$(PACKAGE)-$(VERSION)/src/command.h \
|
||||||
$(PACKAGE)-$(VERSION)/src/gsm.h \
|
$(PACKAGE)-$(VERSION)/src/gsm.h \
|
||||||
$(PACKAGE)-$(VERSION)/src/phone.h \
|
$(PACKAGE)-$(VERSION)/src/phone.h \
|
||||||
$(PACKAGE)-$(VERSION)/src/common.c \
|
$(PACKAGE)-$(VERSION)/src/common.c \
|
||||||
|
@ -16,7 +16,7 @@ INSTALL = install
|
|||||||
|
|
||||||
all: $(TARGETS)
|
all: $(TARGETS)
|
||||||
|
|
||||||
phone_OBJS = callbacks.o gsm.o main.o phone.o
|
phone_OBJS = callbacks.o command.o gsm.o main.o phone.o
|
||||||
phone_CFLAGS = $(CPPFLAGSF) $(CPPFLAGS) $(CFLAGSF) $(CFLAGS)
|
phone_CFLAGS = $(CPPFLAGSF) $(CPPFLAGS) $(CFLAGSF) $(CFLAGS)
|
||||||
phone_LDFLAGS = $(LDFLAGSF) $(LDFLAGS)
|
phone_LDFLAGS = $(LDFLAGSF) $(LDFLAGS)
|
||||||
|
|
||||||
@ -47,7 +47,10 @@ phone-messages: $(phone-messages_OBJS)
|
|||||||
callbacks.o: callbacks.c phone.h callbacks.h
|
callbacks.o: callbacks.c phone.h callbacks.h
|
||||||
$(CC) $(phone_CFLAGS) -c callbacks.c
|
$(CC) $(phone_CFLAGS) -c callbacks.c
|
||||||
|
|
||||||
gsm.o: gsm.c phone.h gsm.h
|
command.o: command.c
|
||||||
|
$(CC) $(phone_CFLAGS) -c command.c
|
||||||
|
|
||||||
|
gsm.o: gsm.c command.h phone.h gsm.h
|
||||||
$(CC) $(phone_CFLAGS) -c gsm.c
|
$(CC) $(phone_CFLAGS) -c gsm.c
|
||||||
|
|
||||||
main.o: main.c phone.h ../config.h
|
main.o: main.c phone.h ../config.h
|
||||||
|
140
src/command.c
Normal file
140
src/command.c
Normal file
@ -0,0 +1,140 @@
|
|||||||
|
/* $Id$ */
|
||||||
|
/* Copyright (c) 2010 Pierre Pronchery <khorben@defora.org> */
|
||||||
|
/* This file is part of DeforaOS Desktop Phone */
|
||||||
|
/* This program 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, version 3 of the License.
|
||||||
|
*
|
||||||
|
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#ifdef DEBUG
|
||||||
|
# include <stdio.h>
|
||||||
|
#endif
|
||||||
|
#include <string.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include "command.h"
|
||||||
|
|
||||||
|
|
||||||
|
/* GSMCommand */
|
||||||
|
/* private */
|
||||||
|
/* types */
|
||||||
|
struct _GSMCommand
|
||||||
|
{
|
||||||
|
GSMPriority priority;
|
||||||
|
char * command;
|
||||||
|
GSMError error;
|
||||||
|
GSMCommandCallback callback;
|
||||||
|
GSMMode mode;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* public */
|
||||||
|
/* functions */
|
||||||
|
/* gsm_command_new */
|
||||||
|
GSMCommand * gsm_command_new(char const * command)
|
||||||
|
{
|
||||||
|
GSMCommand * gsmc;
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf(stderr, "DEBUG: %s(\"%s\")\n", __func__, command);
|
||||||
|
#endif
|
||||||
|
if((gsmc = malloc(sizeof(*gsmc))) == NULL)
|
||||||
|
return NULL; /* XXX report error */
|
||||||
|
gsmc->priority = GSM_PRIORITY_NORMAL;
|
||||||
|
gsmc->command = strdup(command);
|
||||||
|
gsmc->error = GSM_ERROR_UNKNOWN;
|
||||||
|
gsmc->callback = NULL;
|
||||||
|
gsmc->mode = GSM_MODE_COMMAND;
|
||||||
|
/* check errors */
|
||||||
|
if(gsmc->command == NULL)
|
||||||
|
{
|
||||||
|
gsm_command_delete(gsmc);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
return gsmc;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_delete */
|
||||||
|
void gsm_command_delete(GSMCommand * gsmc)
|
||||||
|
{
|
||||||
|
#ifdef DEBUG
|
||||||
|
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
||||||
|
#endif
|
||||||
|
free(gsmc->command);
|
||||||
|
free(gsmc);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* accessors */
|
||||||
|
/* gsm_command_get_callback */
|
||||||
|
GSMCommandCallback gsm_command_get_callback(GSMCommand * gsmc)
|
||||||
|
{
|
||||||
|
return gsmc->callback;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_get_command */
|
||||||
|
char const * gsm_command_get_command(GSMCommand * gsmc)
|
||||||
|
{
|
||||||
|
return gsmc->command;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_get_error */
|
||||||
|
GSMError gsm_command_get_error(GSMCommand * gsmc)
|
||||||
|
{
|
||||||
|
return gsmc->error;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_get_mode */
|
||||||
|
GSMMode gsm_command_get_mode(GSMCommand * gsmc)
|
||||||
|
{
|
||||||
|
return gsmc->mode;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_get_priority */
|
||||||
|
GSMPriority gsm_command_get_priority(GSMCommand * gsmc)
|
||||||
|
{
|
||||||
|
return gsmc->priority;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_set_callback */
|
||||||
|
void gsm_command_set_callback(GSMCommand * gsmc,
|
||||||
|
GSMCommandCallback callback)
|
||||||
|
{
|
||||||
|
gsmc->callback = callback;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_set_error */
|
||||||
|
void gsm_command_set_error(GSMCommand * gsmc, GSMError error)
|
||||||
|
{
|
||||||
|
gsmc->error = error;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_set_mode */
|
||||||
|
void gsm_command_set_mode(GSMCommand * gsmc, GSMMode mode)
|
||||||
|
{
|
||||||
|
gsmc->mode = mode;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* gsm_command_set_priority */
|
||||||
|
void gsm_command_set_priority(GSMCommand * gsmc, GSMPriority priority)
|
||||||
|
{
|
||||||
|
gsmc->priority = priority;
|
||||||
|
}
|
49
src/command.h
Normal file
49
src/command.h
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
/* $Id$ */
|
||||||
|
/* Copyright (c) 2010 Pierre Pronchery <khorben@defora.org> */
|
||||||
|
/* This file is part of DeforaOS Desktop Phone */
|
||||||
|
/* This program 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, version 3 of the License.
|
||||||
|
*
|
||||||
|
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef PHONE_COMMAND_H
|
||||||
|
# define PHONE_COMMAND_H
|
||||||
|
|
||||||
|
# include "gsm.h"
|
||||||
|
|
||||||
|
|
||||||
|
/* GSMCommand */
|
||||||
|
/* public */
|
||||||
|
/* types */
|
||||||
|
typedef struct _GSMCommand GSMCommand;
|
||||||
|
|
||||||
|
typedef void (*GSMCommandCallback)(GSM * gsm);
|
||||||
|
|
||||||
|
|
||||||
|
/* functions */
|
||||||
|
/* commands */
|
||||||
|
GSMCommand * gsm_command_new(char const * command);
|
||||||
|
void gsm_command_delete(GSMCommand * gsmc);
|
||||||
|
|
||||||
|
/* accessors */
|
||||||
|
GSMCommandCallback gsm_command_get_callback(GSMCommand * gsmc);
|
||||||
|
char const * gsm_command_get_command(GSMCommand * gsmc);
|
||||||
|
GSMError gsm_command_get_error(GSMCommand * gsmc);
|
||||||
|
GSMMode gsm_command_get_mode(GSMCommand * gsmc);
|
||||||
|
GSMPriority gsm_command_get_priority(GSMCommand * gsmc);
|
||||||
|
|
||||||
|
void gsm_command_set_callback(GSMCommand * gsmc, GSMCommandCallback callback);
|
||||||
|
void gsm_command_set_error(GSMCommand * gsmc, GSMError error);
|
||||||
|
void gsm_command_set_mode(GSMCommand * gsmc, GSMMode mode);
|
||||||
|
void gsm_command_set_priority(GSMCommand * gsmc, GSMPriority priority);
|
||||||
|
|
||||||
|
#endif /* !PHONE_COMMAND_H */
|
204
src/gsm.c
204
src/gsm.c
@ -26,7 +26,7 @@
|
|||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <libintl.h>
|
#include <libintl.h>
|
||||||
#include <glib.h>
|
#include "command.h"
|
||||||
#include "phone.h"
|
#include "phone.h"
|
||||||
#include "gsm.h"
|
#include "gsm.h"
|
||||||
#define _(string) gettext(string)
|
#define _(string) gettext(string)
|
||||||
@ -36,34 +36,12 @@
|
|||||||
/* GSM */
|
/* GSM */
|
||||||
/* private */
|
/* private */
|
||||||
/* types */
|
/* types */
|
||||||
typedef enum _GSMMode
|
|
||||||
{
|
|
||||||
GSM_MODE_INIT = 0, GSM_MODE_COMMAND, GSM_MODE_PDU
|
|
||||||
} GSMMode;
|
|
||||||
|
|
||||||
typedef enum _GSMPriority
|
|
||||||
{
|
|
||||||
GSM_PRIORITY_LOW = 0, GSM_PRIORITY_NORMAL, GSM_PRIORITY_HIGH,
|
|
||||||
GSM_PRIORITY_HIGHEST
|
|
||||||
} GSMPriority;
|
|
||||||
|
|
||||||
typedef enum _GSMQuirk
|
typedef enum _GSMQuirk
|
||||||
{
|
{
|
||||||
GSM_QUIRK_NONE = 0,
|
GSM_QUIRK_NONE = 0,
|
||||||
GSM_QUIRK_CPIN_QUOTES = 1
|
GSM_QUIRK_CPIN_QUOTES = 1
|
||||||
} GSMQuirk;
|
} GSMQuirk;
|
||||||
|
|
||||||
typedef void (*GSMCommandCallback)(GSM * gsm);
|
|
||||||
|
|
||||||
typedef struct _GSMCommand
|
|
||||||
{
|
|
||||||
GSMPriority priority;
|
|
||||||
char * command;
|
|
||||||
GSMError error;
|
|
||||||
GSMCommandCallback callback;
|
|
||||||
GSMMode mode;
|
|
||||||
} GSMCommand;
|
|
||||||
|
|
||||||
typedef struct _GSMTrigger
|
typedef struct _GSMTrigger
|
||||||
{
|
{
|
||||||
char const * trigger;
|
char const * trigger;
|
||||||
@ -175,18 +153,6 @@ static int _is_code(char const * code);
|
|||||||
static int _is_figure(int c);
|
static int _is_figure(int c);
|
||||||
static int _is_number(char const * number);
|
static int _is_number(char const * number);
|
||||||
|
|
||||||
/* commands */
|
|
||||||
static GSMCommand * _gsm_command_new(char const * command);
|
|
||||||
static void _gsm_command_delete(GSMCommand * command);
|
|
||||||
static char const * _gsm_command_get_command(GSMCommand * command);
|
|
||||||
static GSMMode _gsm_command_get_mode(GSMCommand * gsmc);
|
|
||||||
static GSMPriority _gsm_command_get_priority(GSMCommand * gsmc);
|
|
||||||
static void _gsm_command_set_callback(GSMCommand * gsmc,
|
|
||||||
GSMCommandCallback callback);
|
|
||||||
static void _gsm_command_set_error(GSMCommand * gsmc, GSMError error);
|
|
||||||
static void _gsm_command_set_mode(GSMCommand * gsmc, GSMMode mode);
|
|
||||||
static void _gsm_command_set_priority(GSMCommand * gsmc, GSMPriority priority);
|
|
||||||
|
|
||||||
/* events */
|
/* events */
|
||||||
static int _gsm_event(GSM * gsm, GSMEventType type, ...);
|
static int _gsm_event(GSM * gsm, GSMEventType type, ...);
|
||||||
static int _gsm_event_send(GSM * gsm, GSMEventType type);
|
static int _gsm_event_send(GSM * gsm, GSMEventType type);
|
||||||
@ -626,93 +592,6 @@ static int _is_number(char const * number)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* commands */
|
|
||||||
/* gsm_command_new */
|
|
||||||
static GSMCommand * _gsm_command_new(char const * command)
|
|
||||||
{
|
|
||||||
GSMCommand * gsmc;
|
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
fprintf(stderr, "DEBUG: %s(\"%s\")\n", __func__, command);
|
|
||||||
#endif
|
|
||||||
if((gsmc = malloc(sizeof(*gsmc))) == NULL)
|
|
||||||
return NULL; /* XXX report error */
|
|
||||||
gsmc->priority = GSM_PRIORITY_NORMAL;
|
|
||||||
gsmc->command = strdup(command);
|
|
||||||
gsmc->error = GSM_ERROR_UNKNOWN;
|
|
||||||
gsmc->callback = NULL;
|
|
||||||
gsmc->mode = GSM_MODE_COMMAND;
|
|
||||||
/* check errors */
|
|
||||||
if(gsmc->command == NULL)
|
|
||||||
{
|
|
||||||
_gsm_command_delete(gsmc);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
return gsmc;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* gsm_command_delete */
|
|
||||||
static void _gsm_command_delete(GSMCommand * gsmc)
|
|
||||||
{
|
|
||||||
#ifdef DEBUG
|
|
||||||
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
|
||||||
#endif
|
|
||||||
free(gsmc->command);
|
|
||||||
free(gsmc);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* gsm_command_get_command */
|
|
||||||
static char const * _gsm_command_get_command(GSMCommand * gsmc)
|
|
||||||
{
|
|
||||||
return gsmc->command;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* gsm_command_get_mode */
|
|
||||||
static GSMMode _gsm_command_get_mode(GSMCommand * gsmc)
|
|
||||||
{
|
|
||||||
return gsmc->mode;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* gsm_command_get_priority */
|
|
||||||
static GSMPriority _gsm_command_get_priority(GSMCommand * gsmc)
|
|
||||||
{
|
|
||||||
return gsmc->priority;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* gsm_command_set_callback */
|
|
||||||
static void _gsm_command_set_callback(GSMCommand * gsmc,
|
|
||||||
GSMCommandCallback callback)
|
|
||||||
{
|
|
||||||
gsmc->callback = callback;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* gsm_command_set_error */
|
|
||||||
static void _gsm_command_set_error(GSMCommand * gsmc, GSMError error)
|
|
||||||
{
|
|
||||||
gsmc->error = error;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* gsm_command_set_mode */
|
|
||||||
static void _gsm_command_set_mode(GSMCommand * gsmc, GSMMode mode)
|
|
||||||
{
|
|
||||||
gsmc->mode = mode;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* gsm_command_set_priority */
|
|
||||||
static void _gsm_command_set_priority(GSMCommand * gsmc, GSMPriority priority)
|
|
||||||
{
|
|
||||||
gsmc->priority = priority;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* events */
|
/* events */
|
||||||
/* gsm_event */
|
/* gsm_event */
|
||||||
static int _gsm_event(GSM * gsm, GSMEventType type, ...)
|
static int _gsm_event(GSM * gsm, GSMEventType type, ...)
|
||||||
@ -1094,23 +973,23 @@ static int _gsm_modem_send_message(GSM * gsm, char const * number,
|
|||||||
snprintf(buf1, len1, "%s%lu", cmd1, (len2 - 1) / 2);
|
snprintf(buf1, len1, "%s%lu", cmd1, (len2 - 1) / 2);
|
||||||
free(addr);
|
free(addr);
|
||||||
free(sept);
|
free(sept);
|
||||||
if((gsmc = _gsm_command_new(buf1)) != NULL
|
if((gsmc = gsm_command_new(buf1)) != NULL
|
||||||
&& (ret = _gsm_queue_command(gsm, gsmc)) == 0)
|
&& (ret = _gsm_queue_command(gsm, gsmc)) == 0)
|
||||||
{
|
{
|
||||||
_gsm_command_set_error(gsmc, GSM_ERROR_MESSAGE_SEND_FAILED);
|
gsm_command_set_error(gsmc, GSM_ERROR_MESSAGE_SEND_FAILED);
|
||||||
_gsm_command_set_mode(gsmc, GSM_MODE_PDU);
|
gsm_command_set_mode(gsmc, GSM_MODE_PDU);
|
||||||
_gsm_command_set_priority(gsmc, GSM_PRIORITY_HIGHEST);
|
gsm_command_set_priority(gsmc, GSM_PRIORITY_HIGHEST);
|
||||||
if((gsmc = _gsm_command_new(buf2)) != NULL
|
if((gsmc = gsm_command_new(buf2)) != NULL
|
||||||
/* XXX if this fails we're stuck in PDU mode */
|
/* XXX if this fails we're stuck in PDU mode */
|
||||||
&& (ret = _gsm_queue_command(gsm, gsmc)) == 0)
|
&& (ret = _gsm_queue_command(gsm, gsmc)) == 0)
|
||||||
{
|
{
|
||||||
_gsm_command_set_error(gsmc,
|
gsm_command_set_error(gsmc,
|
||||||
GSM_ERROR_MESSAGE_SEND_FAILED);
|
GSM_ERROR_MESSAGE_SEND_FAILED);
|
||||||
_gsm_command_set_priority(gsmc, GSM_PRIORITY_HIGHEST);
|
gsm_command_set_priority(gsmc, GSM_PRIORITY_HIGHEST);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(ret != 0)
|
if(ret != 0)
|
||||||
_gsm_command_delete(gsmc);
|
gsm_command_delete(gsmc);
|
||||||
free(buf1);
|
free(buf1);
|
||||||
free(buf2);
|
free(buf2);
|
||||||
return ret;
|
return ret;
|
||||||
@ -1411,9 +1290,11 @@ static int _gsm_parse_line(GSM * gsm, char const * line, gboolean * answered)
|
|||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
GSMCommand * gsmc;
|
GSMCommand * gsmc;
|
||||||
|
GSMCommandCallback callback;
|
||||||
GSMError error = GSM_ERROR_UNKNOWN;
|
GSMError error = GSM_ERROR_UNKNOWN;
|
||||||
char const * cmd;
|
char const * cmd;
|
||||||
size_t j;
|
size_t j;
|
||||||
|
int c;
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
fprintf(stderr, "DEBUG: %s(\"%s\")\n", __func__, line);
|
fprintf(stderr, "DEBUG: %s(\"%s\")\n", __func__, line);
|
||||||
@ -1428,16 +1309,16 @@ static int _gsm_parse_line(GSM * gsm, char const * line, gboolean * answered)
|
|||||||
GSM_CALL_TYPE_UNKNOWN);
|
GSM_CALL_TYPE_UNKNOWN);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
gsmc = g_slist_nth_data(gsm->queue, 0);
|
||||||
if(strcmp(line, "OK") == 0)
|
if(strcmp(line, "OK") == 0)
|
||||||
{
|
{
|
||||||
if(answered != NULL)
|
if(answered != NULL)
|
||||||
*answered = TRUE;
|
*answered = TRUE;
|
||||||
if((gsmc = g_slist_nth_data(gsm->queue, 0)) != NULL
|
if(gsmc != NULL && (callback = gsm_command_get_callback(gsmc))
|
||||||
&& gsmc->callback != NULL)
|
!= NULL)
|
||||||
gsmc->callback(gsm);
|
callback(gsm);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
gsmc = g_slist_nth_data(gsm->queue, 0);
|
|
||||||
for(i = 0; _gsm_errors[i] != NULL; i++)
|
for(i = 0; _gsm_errors[i] != NULL; i++)
|
||||||
{
|
{
|
||||||
if(strcmp(_gsm_errors[i], line) != 0)
|
if(strcmp(_gsm_errors[i], line) != 0)
|
||||||
@ -1445,7 +1326,7 @@ static int _gsm_parse_line(GSM * gsm, char const * line, gboolean * answered)
|
|||||||
if(answered != NULL)
|
if(answered != NULL)
|
||||||
*answered = TRUE;
|
*answered = TRUE;
|
||||||
if(gsmc != NULL)
|
if(gsmc != NULL)
|
||||||
error = gsmc->error;
|
error = gsm_command_get_error(gsmc);
|
||||||
_gsm_event(gsm, GSM_EVENT_TYPE_ERROR, error, line);
|
_gsm_event(gsm, GSM_EVENT_TYPE_ERROR, error, line);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1455,10 +1336,11 @@ static int _gsm_parse_line(GSM * gsm, char const * line, gboolean * answered)
|
|||||||
return _gsm_triggers[i].callback(gsm,
|
return _gsm_triggers[i].callback(gsm,
|
||||||
&line[_gsm_triggers[i].trigger_cnt]);
|
&line[_gsm_triggers[i].trigger_cnt]);
|
||||||
/* XXX look for a potential trigger */
|
/* XXX look for a potential trigger */
|
||||||
if(gsmc != NULL && (cmd = _gsm_command_get_command(gsmc)) != NULL
|
if(gsmc != NULL && (cmd = gsm_command_get_command(gsmc)) != NULL
|
||||||
&& strncmp(cmd, "AT+", 3) == 0 && isupper(cmd[3]))
|
&& strncmp(cmd, "AT+", 3) == 0 && isupper((c = cmd[3])))
|
||||||
{
|
{
|
||||||
for(cmd += 2, j = 2; cmd[j] != '\0' && isupper(cmd[j]); j++);
|
for(cmd += 2, j = 2; cmd[j] != '\0' && isupper((c = cmd[j]));
|
||||||
|
j++);
|
||||||
for(i = 0; _gsm_triggers[i].trigger != NULL; i++)
|
for(i = 0; _gsm_triggers[i].trigger != NULL; i++)
|
||||||
if(strncmp(cmd, _gsm_triggers[i].trigger, j) == 0)
|
if(strncmp(cmd, _gsm_triggers[i].trigger, j) == 0)
|
||||||
return _gsm_triggers[i].callback(gsm, line);
|
return _gsm_triggers[i].callback(gsm, line);
|
||||||
@ -1475,47 +1357,47 @@ static GSMCommand * _gsm_queue(GSM * gsm, char const * command)
|
|||||||
|
|
||||||
if(command == NULL || command[0] == '\0')
|
if(command == NULL || command[0] == '\0')
|
||||||
return NULL;
|
return NULL;
|
||||||
if((gsmc = _gsm_command_new(command)) == NULL)
|
if((gsmc = gsm_command_new(command)) == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
if(_gsm_queue_command(gsm, gsmc) == 0)
|
if(_gsm_queue_command(gsm, gsmc) == 0)
|
||||||
return gsmc;
|
return gsmc;
|
||||||
_gsm_command_delete(gsmc);
|
gsm_command_delete(gsmc);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* gsm_queue_command */
|
/* gsm_queue_command */
|
||||||
static int _gsm_queue_command(GSM * gsm, GSMCommand * command)
|
static int _gsm_queue_command(GSM * gsm, GSMCommand * gsmc)
|
||||||
{
|
{
|
||||||
GSMPriority priority;
|
GSMPriority priority;
|
||||||
GSList * l;
|
GSList * l;
|
||||||
GSMCommand * p;
|
GSMCommand * p;
|
||||||
|
|
||||||
if(command == NULL)
|
if(gsmc == NULL)
|
||||||
return 1;
|
return 1;
|
||||||
/* the GSM_PRIORITY_HIGHEST priority is meant to avoid races */
|
/* the GSM_PRIORITY_HIGHEST priority is meant to avoid races */
|
||||||
if((priority = _gsm_command_get_priority(command)) > GSM_PRIORITY_HIGH)
|
if((priority = gsm_command_get_priority(gsmc)) > GSM_PRIORITY_HIGH)
|
||||||
priority = GSM_PRIORITY_HIGH;
|
priority = GSM_PRIORITY_HIGH;
|
||||||
for(l = gsm->queue; l != NULL; l = l->next)
|
for(l = gsm->queue; l != NULL; l = l->next)
|
||||||
{
|
{
|
||||||
p = l->data;
|
p = l->data;
|
||||||
if(_gsm_command_get_priority(p) < priority)
|
if(gsm_command_get_priority(p) < priority)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if(l != NULL)
|
if(l != NULL)
|
||||||
gsm->queue = g_slist_insert_before(gsm->queue, l, command);
|
gsm->queue = g_slist_insert_before(gsm->queue, l, gsmc);
|
||||||
else if(gsm->queue == NULL && gsm->mode == GSM_MODE_COMMAND)
|
else if(gsm->queue == NULL && gsm->mode == GSM_MODE_COMMAND)
|
||||||
{
|
{
|
||||||
gsm->queue = g_slist_append(gsm->queue, command);
|
gsm->queue = g_slist_append(gsm->queue, gsmc);
|
||||||
_gsm_queue_push(gsm);
|
_gsm_queue_push(gsm);
|
||||||
}
|
}
|
||||||
else if(gsm->mode == GSM_MODE_INIT && gsm->wr_source == 0)
|
else if(gsm->mode == GSM_MODE_INIT && gsm->wr_source == 0)
|
||||||
{
|
{
|
||||||
gsm->queue = g_slist_append(gsm->queue, command);
|
gsm->queue = g_slist_append(gsm->queue, gsmc);
|
||||||
_gsm_queue_push(gsm);
|
_gsm_queue_push(gsm);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
gsm->queue = g_slist_append(gsm->queue, command);
|
gsm->queue = g_slist_append(gsm->queue, gsmc);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1528,7 +1410,7 @@ static int _gsm_queue_with_error(GSM * gsm, char const * command,
|
|||||||
|
|
||||||
if((gsmc = _gsm_queue(gsm, command)) == NULL)
|
if((gsmc = _gsm_queue(gsm, command)) == NULL)
|
||||||
return 1;
|
return 1;
|
||||||
_gsm_command_set_error(gsmc, error);
|
gsm_command_set_error(gsmc, error);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1539,7 +1421,7 @@ static void _gsm_queue_flush(GSM * gsm)
|
|||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
fprintf(stderr, "DEBUG: %s()\n", __func__);
|
||||||
#endif
|
#endif
|
||||||
g_slist_foreach(gsm->queue, (GFunc)_gsm_command_delete, NULL);
|
g_slist_foreach(gsm->queue, (GFunc)gsm_command_delete, NULL);
|
||||||
g_slist_free(gsm->queue);
|
g_slist_free(gsm->queue);
|
||||||
gsm->queue = NULL;
|
gsm->queue = NULL;
|
||||||
free(gsm->rd_buf);
|
free(gsm->rd_buf);
|
||||||
@ -1585,15 +1467,15 @@ static int _gsm_queue_full_mode(GSM * gsm, GSMPriority priority,
|
|||||||
|
|
||||||
if(command == NULL || command[0] == '\0')
|
if(command == NULL || command[0] == '\0')
|
||||||
return 1;
|
return 1;
|
||||||
if((gsmc = _gsm_command_new(command)) == NULL)
|
if((gsmc = gsm_command_new(command)) == NULL)
|
||||||
return 1;
|
return 1;
|
||||||
_gsm_command_set_priority(gsmc, priority);
|
gsm_command_set_priority(gsmc, priority);
|
||||||
_gsm_command_set_error(gsmc, error);
|
gsm_command_set_error(gsmc, error);
|
||||||
_gsm_command_set_callback(gsmc, callback);
|
gsm_command_set_callback(gsmc, callback);
|
||||||
_gsm_command_set_mode(gsmc, mode);
|
gsm_command_set_mode(gsmc, mode);
|
||||||
if(_gsm_queue_command(gsm, gsmc) == 0)
|
if(_gsm_queue_command(gsm, gsmc) == 0)
|
||||||
return 0;
|
return 0;
|
||||||
_gsm_command_delete(gsmc);
|
gsm_command_delete(gsmc);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1609,7 +1491,7 @@ static void _gsm_queue_pop(GSM * gsm)
|
|||||||
if(gsm->queue == NULL)
|
if(gsm->queue == NULL)
|
||||||
return;
|
return;
|
||||||
gsmc = gsm->queue->data;
|
gsmc = gsm->queue->data;
|
||||||
_gsm_command_delete(gsmc);
|
gsm_command_delete(gsmc);
|
||||||
gsm->queue = g_slist_remove(gsm->queue, gsmc);
|
gsm->queue = g_slist_remove(gsm->queue, gsmc);
|
||||||
#if 0 /* FIXME this is useless */
|
#if 0 /* FIXME this is useless */
|
||||||
if(gsm->mode != GSM_MODE_COMMAND)
|
if(gsm->mode != GSM_MODE_COMMAND)
|
||||||
@ -1622,6 +1504,7 @@ static void _gsm_queue_pop(GSM * gsm)
|
|||||||
static int _gsm_queue_push(GSM * gsm)
|
static int _gsm_queue_push(GSM * gsm)
|
||||||
{
|
{
|
||||||
GSMCommand * gsmc;
|
GSMCommand * gsmc;
|
||||||
|
char const * command;
|
||||||
char const suffix[] = "\r\n";
|
char const suffix[] = "\r\n";
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
@ -1630,10 +1513,11 @@ static int _gsm_queue_push(GSM * gsm)
|
|||||||
if(gsm->queue == NULL)
|
if(gsm->queue == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
gsmc = gsm->queue->data;
|
gsmc = gsm->queue->data;
|
||||||
gsm->wr_buf_cnt = strlen(gsmc->command) + sizeof(suffix);
|
command = gsm_command_get_command(gsmc);
|
||||||
|
gsm->wr_buf_cnt = strlen(command) + sizeof(suffix);
|
||||||
if((gsm->wr_buf = malloc(gsm->wr_buf_cnt)) == NULL)
|
if((gsm->wr_buf = malloc(gsm->wr_buf_cnt)) == NULL)
|
||||||
return 1;
|
return 1;
|
||||||
snprintf(gsm->wr_buf, gsm->wr_buf_cnt--, "%s%s", gsmc->command, suffix);
|
snprintf(gsm->wr_buf, gsm->wr_buf_cnt--, "%s%s", command, suffix);
|
||||||
/* FIXME shouldn't it always be the case? flush input queue first? */
|
/* FIXME shouldn't it always be the case? flush input queue first? */
|
||||||
if(gsm->channel != NULL && gsm->wr_source == 0)
|
if(gsm->channel != NULL && gsm->wr_source == 0)
|
||||||
gsm->wr_source = g_io_add_watch(gsm->channel, G_IO_OUT,
|
gsm->wr_source = g_io_add_watch(gsm->channel, G_IO_OUT,
|
||||||
@ -2080,6 +1964,6 @@ static gboolean _on_watch_can_write(GIOChannel * source, GIOCondition condition,
|
|||||||
if(gsm->mode == GSM_MODE_INIT)
|
if(gsm->mode == GSM_MODE_INIT)
|
||||||
_gsm_queue_pop(gsm);
|
_gsm_queue_pop(gsm);
|
||||||
else if(gsm->queue != NULL && (gsmc = gsm->queue->data) != NULL)
|
else if(gsm->queue != NULL && (gsmc = gsm->queue->data) != NULL)
|
||||||
gsm->mode = _gsm_command_get_mode(gsmc);
|
gsm->mode = gsm_command_get_mode(gsmc);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
13
src/gsm.h
13
src/gsm.h
@ -18,6 +18,8 @@
|
|||||||
#ifndef PHONE_GSM_H
|
#ifndef PHONE_GSM_H
|
||||||
# define PHONE_GSM_H
|
# define PHONE_GSM_H
|
||||||
|
|
||||||
|
# include <glib.h>
|
||||||
|
|
||||||
|
|
||||||
/* GSM */
|
/* GSM */
|
||||||
/* types */
|
/* types */
|
||||||
@ -68,6 +70,11 @@ typedef enum _GSMMessageFormat
|
|||||||
GSM_MESSAGE_FORMAT_TEXT = 1
|
GSM_MESSAGE_FORMAT_TEXT = 1
|
||||||
} GSMMessageFormat;
|
} GSMMessageFormat;
|
||||||
|
|
||||||
|
typedef enum _GSMMode
|
||||||
|
{
|
||||||
|
GSM_MODE_INIT = 0, GSM_MODE_COMMAND, GSM_MODE_PDU
|
||||||
|
} GSMMode;
|
||||||
|
|
||||||
typedef enum _GSMOperatorFormat
|
typedef enum _GSMOperatorFormat
|
||||||
{
|
{
|
||||||
GSM_OPERATOR_FORMAT_LONG = 0,
|
GSM_OPERATOR_FORMAT_LONG = 0,
|
||||||
@ -84,6 +91,12 @@ typedef enum _GSMOperatorMode
|
|||||||
GSM_OPERATOR_MODE_MANUAL_WITH_FALLBACK = 4
|
GSM_OPERATOR_MODE_MANUAL_WITH_FALLBACK = 4
|
||||||
} GSMOperatorMode;
|
} GSMOperatorMode;
|
||||||
|
|
||||||
|
typedef enum _GSMPriority
|
||||||
|
{
|
||||||
|
GSM_PRIORITY_LOW = 0, GSM_PRIORITY_NORMAL, GSM_PRIORITY_HIGH,
|
||||||
|
GSM_PRIORITY_HIGHEST
|
||||||
|
} GSMPriority;
|
||||||
|
|
||||||
typedef enum _GSMRegistrationReport
|
typedef enum _GSMRegistrationReport
|
||||||
{
|
{
|
||||||
GSM_REGISTRATION_REPORT_DISABLE_UNSOLLICITED = 0,
|
GSM_REGISTRATION_REPORT_DISABLE_UNSOLLICITED = 0,
|
||||||
|
@ -2,7 +2,7 @@ targets=phone,phone-contacts,phone-dialer,phone-messages
|
|||||||
cflags_force=-W
|
cflags_force=-W
|
||||||
cflags=-Wall -g -O2 -pedantic `pkg-config --cflags gtk+-2.0`
|
cflags=-Wall -g -O2 -pedantic `pkg-config --cflags gtk+-2.0`
|
||||||
ldflags_force=`pkg-config --libs gtk+-2.0`
|
ldflags_force=`pkg-config --libs gtk+-2.0`
|
||||||
dist=Makefile,callbacks.h,gsm.h,phone.h,common.c
|
dist=Makefile,callbacks.h,command.h,gsm.h,phone.h,common.c
|
||||||
|
|
||||||
[phone-contacts]
|
[phone-contacts]
|
||||||
type=binary
|
type=binary
|
||||||
@ -30,14 +30,14 @@ depends=common.c
|
|||||||
|
|
||||||
[phone]
|
[phone]
|
||||||
type=binary
|
type=binary
|
||||||
sources=callbacks.c,gsm.c,main.c,phone.c
|
sources=callbacks.c,command.c,gsm.c,main.c,phone.c
|
||||||
install=$(BINDIR)
|
install=$(BINDIR)
|
||||||
|
|
||||||
[callbacks.c]
|
[callbacks.c]
|
||||||
depends=phone.h,callbacks.h
|
depends=phone.h,callbacks.h
|
||||||
|
|
||||||
[gsm.c]
|
[gsm.c]
|
||||||
depends=phone.h,gsm.h
|
depends=command.h,phone.h,gsm.h
|
||||||
|
|
||||||
[main.c]
|
[main.c]
|
||||||
depends=phone.h,../config.h
|
depends=phone.h,../config.h
|
||||||
|
Loading…
Reference in New Issue
Block a user