--- smsdaemon/GsmModem.h 2008/12/07 16:27:34 144 +++ smsdaemon/ModemTransceiver.h 2008/12/18 06:53:29 196 @@ -1,10 +1,9 @@ -#ifndef __GSMMODEM_H__ -#define __GSMMODEM_H__ +#ifndef __MODEMTRANSCEIVER_H__ +#define __MODEMTRANSCEIVER_H__ -/* using http://sourceforge.net/projects/libserial/ - */ -#include "IGsmModem.h" + +#include "ISmsTransceiver.h" #include #include @@ -14,16 +13,16 @@ class SerialPort; -class GsmModem : public IGsmModem +class ModemTransceiver : public ISmsTransceiver { public: - GsmModem(SerialPort& serialport); - virtual ~GsmModem() {} + ModemTransceiver(SerialPort& serialport); + virtual ~ModemTransceiver() {} void Init(); virtual void SendSms(std::string to, std::string message, bool allowMultipart); - void SendSmsPdu(std::string pdu, int len); + void SendSmsPdu(std::string pdu, int len); virtual std::vector ReadSms(bool readAll=false); @@ -33,6 +32,10 @@ std::string GetResponse(); std::string Command(std::string command, std::string term = "OK\r\n"); + //decode an CMGF=1 text string + SMS FromRawString(const std::string& input); + SMS FromPduString(const std::string& input); + void HandlePincode(); void WaitForSimcard(); @@ -40,29 +43,5 @@ SerialPort& m_port; }; -class DebugGsmModem : public IGsmModem -{ -public: - DebugGsmModem() : _print(false) {} - DebugGsmModem(bool print) : _print(print) {} - - - virtual std::vector ReadSms(bool readAll=false); - virtual void SendSms(std::string to, std::string message, bool allowMultipart); - - virtual void DeleteSms(std::string smsIndex) {} - virtual int DeleteAllSms() { return 0;} - - - - std::string GetTo() {return _to;} - std::string GetMessage() {return _message;} - bool GetMultipart() {return _multipart;} -private: - std::string _to; - std::string _message; - bool _multipart; - bool _print; -}; -#endif // __GSMMODEM_H__ +#endif // __MODEMTRANSCEIVER_H__