-rw-r--r-- | libkcal/phoneformat.cpp | 897 | ||||
-rw-r--r-- | libkcal/phoneformat.h | 8 |
2 files changed, 260 insertions, 645 deletions
diff --git a/libkcal/phoneformat.cpp b/libkcal/phoneformat.cpp index fd6b6af..c97b43d 100644 --- a/libkcal/phoneformat.cpp +++ b/libkcal/phoneformat.cpp @@ -64,29 +64,147 @@ class PhoneParser : public QObject { public: PhoneParser( Calendar *calendar, QString profileName ) : mCalendar( calendar ), mProfileName ( profileName ) { - oldCategories = 0; + ; } - - bool startElement( Calendar *existingCalendar, GSM_CalendarEntry* Note, QString qName ) + bool readTodo( Calendar *existingCalendar,GSM_ToDoEntry *ToDo, GSM_StateMachine* s) { - QStringList attList; - /* -// pending csum - int i = 1; - bool skip = true; - int max = attList.count() -2; - while ( i < max ) { - if ( !attList[i].isEmpty() ) { - skip = false; + + int id = ToDo->Location; + Todo *todo; + todo = existingCalendar->todo( mProfileName ,QString::number( id ) ); + if (todo ) + todo = (Todo *)todo->clone(); + else + todo = new Todo; + todo->setID( mProfileName,QString::number( id ) ); + todo->setTempSyncStat(SYNC_TEMPSTATE_NEW_EXTERNAL ); + int priority; + switch (ToDo->Priority) { + case GSM_Priority_Low : priority = 1; break; + case GSM_Priority_Medium : priority = 3; break; + case GSM_Priority_High : priority = 5; break; + default :priority = 3 ; break; + } + todo->setPriority( priority ); + GSM_Phone_Functions *Phone; + Phone=s->Phone.Functions; + int j; + GSM_DateTime* dtp; + bool alarm = false; + QDateTime alarmDt; + GSM_Category Category; + int error; + QString completedString = "no"; + for (j=0;j<ToDo->EntriesNum;j++) { + switch (ToDo->Entries[j].EntryType) { + case TODO_END_DATETIME: + dtp = &ToDo->Entries[j].Date ; + todo->setDtDue (fromGSM ( dtp )); break; + case TODO_COMPLETED: + if ( ToDo->Entries[j].Number == 1 ) { + todo->setCompleted( true ); + completedString = "yes"; } - ++i ; + else { + todo->setCompleted( false ); } - if ( skip ) - return false; - ulong cSum = PhoneFormat::getCsum(attList ); - */ - if ( qName == "Event" ) { + break; + case TODO_ALARM_DATETIME: + dtp = &ToDo->Entries[j].Date ; + alarm = true; + alarmDt = fromGSM ( dtp ); + break; + case TODO_SILENT_ALARM_DATETIME: + dtp = &ToDo->Entries[j].Date ; + alarm = true; + alarmDt = fromGSM ( dtp ); + break; + case TODO_TEXT: + todo->setSummary( QString ( (const char*) ToDo->Entries[j].Text )); + break; + case TODO_PRIVATE: + if ( ToDo->Entries[j].Number == 1 ) + todo->setSecrecy( Incidence::SecrecyPrivate ); + else + todo->setSecrecy( Incidence::SecrecyPublic ); + break; + case TODO_CATEGORY: + Category.Location = ToDo->Entries[j].Number; + Category.Type = Category_ToDo; + error=Phone->GetCategory(s, &Category); + if (error == ERR_NONE) { + QStringList cat = todo->categories(); + QString nCat = QString ( (const char*)Category.Name ); + if ( !nCat.isEmpty() ) + if ( !cat.contains( nCat )) { + cat << nCat; + todo->setCategories( cat ); + } + } + break; + case TODO_CONTACTID: +#if 0 + // not supported + entry.Location = ToDo->Entries[j].Number; + entry.MemoryType = MEM_ME; + error=Phone->GetMemory(s, &entry); + if (error == ERR_NONE) { + name = GSM_PhonebookGetEntryName(&entry); + if (name != NULL) { + printmsg("Contact ID : \"%s\" (%d)\n", DecodeUnicodeConsole(name), ToDo->Entries[j].Number); + } else { + printmsg("Contact ID : %d\n",ToDo->Entries[j].Number); + } + } else { + printmsg("Contact : %d\n",ToDo->Entries[j].Number); + } +#endif + break; + case TODO_PHONE: +#if 0 + // not supported + printmsg("Phone : \"%s\"\n",DecodeUnicodeConsole(ToDo->Entries[j].Text)); +#endif + break; + } + } + QString alarmString = ""; + // strange 0 semms to mean: alarm enabled + if ( alarm ) { + Alarm *alarm; + if ( todo->alarms().count() > 0 ) + alarm = todo->alarms().first(); + else { + alarm = new Alarm( todo ); + todo->addAlarm( alarm ); + } + alarm->setType( Alarm::Audio ); + alarm->setEnabled( true ); + int alarmOffset = alarmDt.secsTo( todo->dtStart() ); + alarm->setStartOffset( alarmOffset ); + alarmString = QString::number( alarmOffset ); + } + // csum ***************************************** + QStringList attList; + uint cSum; + if ( todo->hasDueDate() ) + attList << dtToString ( todo->dtDue() ); + attList << QString::number( id ); + attList << todo->summary(); + attList << completedString; + attList << alarmString; + attList << todo->categoriesStr(); + attList << todo->secrecyStr(); + cSum = PhoneFormat::getCsum(attList ); + todo->setCsum( mProfileName, QString::number( cSum )); + mCalendar->addTodo( todo); + + return true; + } + bool readEvent( Calendar *existingCalendar, GSM_CalendarEntry* Note) + { + int id = Note->Location; Event *event; event = existingCalendar->event( mProfileName ,QString::number( id ) ); @@ -94,8 +212,7 @@ class PhoneParser : public QObject event = (Event*)event->clone(); else event = new Event; - event->setID( mProfileName, attList[0] ); - // pending event->setCsum( "Sharp_DTM", QString::number( cSum )); + event->setID( mProfileName,QString::number( id ) ); event->setTempSyncStat(SYNC_TEMPSTATE_NEW_EXTERNAL ); @@ -106,6 +223,7 @@ class PhoneParser : public QObject int repeat_weekofmonth = -1; int repeat_month = -1; int repeat_frequency = -1; + int rec_type = -1; GSM_DateTime repeat_startdate = {0,0,0,0,0,0,0}; GSM_DateTime repeat_stopdate = {0,0,0,0,0,0,0}; GSM_DateTime* dtp; @@ -147,6 +265,7 @@ class PhoneParser : public QObject alarmDt = fromGSM ( dtp ); break; case CAL_RECURRANCE: + rec_type = Note->Entries[i].Number; //printmsg("Repeat : %d day%s\n",Note->Entries[i].Number/24,((Note->Entries[i].Number/24)>1) ? "s":"" ); break; case CAL_TEXT: @@ -159,7 +278,11 @@ class PhoneParser : public QObject //printmsg("Phone : \"%s\"\n",DecodeUnicodeConsole(Note->Entries[i].Text)); break; case CAL_PRIVATE: - //printmsg("Private : %s\n",Note->Entries[i].Number == 1 ? "Yes" : "No"); + if ( Note->Entries[i].Number == 1 ) + event->setSecrecy( Incidence::SecrecyPrivate ); + else + event->setSecrecy( Incidence::SecrecyPublic ); + break; case CAL_CONTACTID: #if 0 @@ -221,8 +344,20 @@ class PhoneParser : public QObject #endif - QString rtype = attList[11]; + QString recurString = "no"; if ( repeating ) { + recurString = "y"; + if ( repeat_dayofweek >= 0 ) + recurString += "dow" + QString::number (repeat_dayofweek); + if ( repeat_day >= 0 ) + recurString += "d" + QString::number (repeat_day); + if ( repeat_weekofmonth >= 0 ) + recurString += "w" + QString::number (repeat_weekofmonth); + if ( repeat_month >= 0 ) + recurString += "m" + QString::number ( repeat_month ); + if ( repeat_frequency >= 0 ) + recurString += "f" + QString::number (repeat_frequency ); + int rtype = 0; // qDebug("recurs "); QDate startDate, endDate; @@ -256,6 +391,12 @@ class PhoneParser : public QObject 2 monthpos;x 3 monthlyday; 4 rYearlyMont + bool repeating = false; + int repeat_dayofweek = -1; + int repeat_day = -1; + int repeat_weekofmonth = -1; + int repeat_month = -1; + int repeat_frequency = -1; */ int dayOfWeek = startDate.dayOfWeek(); if ( repeat_weekofmonth >= 0 ) { @@ -301,9 +442,10 @@ class PhoneParser : public QObject event->recurrence()->unsetRecurs(); } - QString categoryList = attList[1] ; - event->setCategories( lookupCategories( categoryList ) ); - + QStringList categoryList; + categoryList << getCategory( Note ); + event->setCategories( categoryList ); + QString alarmString = ""; // strange 0 semms to mean: alarm enabled if ( alarm ) { Alarm *alarm; @@ -317,89 +459,28 @@ class PhoneParser : public QObject alarm->setEnabled( true ); int alarmOffset = alarmDt.secsTo( event->dtStart() ); alarm->setStartOffset( alarmOffset ); + alarmString = QString::number( alarmOffset ); } + // csum ***************************************** + QStringList attList; + uint cSum; + attList << dtToString ( event->dtStart() ); + attList << dtToString ( event->dtEnd() ); + attList << QString::number( id ); + attList << event->summary(); + attList << event->location(); + attList << alarmString; + attList << recurString; + attList << event->categoriesStr(); + attList << event->secrecyStr(); + cSum = PhoneFormat::getCsum(attList ); + event->setCsum( mProfileName, QString::number( cSum )); mCalendar->addEvent( event); - } else if ( qName == "Todo" ) { -#if 0 - Todo *todo; - - todo = existingCalendar->todo( attList[0] ); - if (todo ) - todo = (Todo*)todo->clone(); - else - todo = new Todo; - -//CARDID,CATEGORY,ETDY,LTDY,FNDY,MARK,PRTY,TITL,MEM1 -// 0 1 2 3 4 5 6 7 8 -//1,,,,,1,4,Loch zumachen,"" -//3,Privat,20040317T000000,20040318T000000,20040319T000000,0,5,Call bbb,"notes123 bbb gggg ""bb "" " -//2,"Familie,Freunde,Holiday",20040318T000000,20040324T000000,20040317T000000,1,2,tod2,notes - //todo->setZaurusId( attList[0] ); - //todo->setZaurusUid( cSum ); - //todo->setZaurusStat( -2 ); - - todo->setSummary( attList[7] ); - todo->setDescription( attList[8]); - - int priority = attList[6].toInt(); - if ( priority == 0 ) priority = 3; - todo->setPriority( priority ); - - QString categoryList = attList[1]; - todo->setCategories( lookupCategories( categoryList ) ); - - - - QString hasDateStr = attList[3]; // due - if ( !hasDateStr.isEmpty() ) { - if ( hasDateStr.right(6) == "000000" ) { - todo->setDtDue( QDateTime(fromString( hasDateStr, false ).date(), QTime(0,0,0 )) ); - todo->setFloats( true ); - } - else { - todo->setDtDue( fromString( hasDateStr ) ); - todo->setFloats( false ); - } - - todo->setHasDueDate( true ); - } - hasDateStr = attList[2];//start - if ( !hasDateStr.isEmpty() ) { - - todo->setDtStart( fromString( hasDateStr ) ); - todo->setHasStartDate( true); - } else - todo->setHasStartDate( false ); - hasDateStr = attList[4];//completed - if ( !hasDateStr.isEmpty() ) { - todo->setCompleted(fromString( hasDateStr ) ); - } - QString completedStr = attList[5]; - if ( completedStr == "0" ) - todo->setCompleted( true ); - else - todo->setCompleted( false ); - mCalendar->addTodo( todo ); -#endif - - } else if ( qName == "Category" ) { - /* - QString id = attributes.value( "id" ); - QString name = attributes.value( "name" ); - setCategory( id, name ); - */ - } - //qDebug("end "); return true; } - void setCategoriesList ( QStringList * c ) - { - oldCategories = c; - } - QDateTime fromGSM ( GSM_DateTime* dtp, bool useTz = true ) { QDateTime dt; int y,m,t,h,min,sec; @@ -417,58 +498,80 @@ class PhoneParser : public QObject return dt; } - QDate datefromGSM ( GSM_DateTime* dtp ) { - return QDate ( dtp->Year, dtp->Month, dtp->Day ); - } - protected: - QDateTime toDateTime( const QString &value ) + + QString dtToString( const QDateTime& dti, bool useTZ = false ) { + QString datestr; + QString timestr; + int offset = KGlobal::locale()->localTimeOffset( dti ); QDateTime dt; - dt.setTime_t( value.toUInt() ); - - return dt; + if (useTZ) + dt = dti.addSecs ( -(offset*60)); + else + dt = dti; + if(dt.date().isValid()){ + const QDate& date = dt.date(); + datestr.sprintf("%04d%02d%02d", + date.year(), date.month(), date.day()); } - - QStringList lookupCategories( const QString &categoryList ) - { - QStringList categoryIds = QStringList::split( ";", categoryList ); - QStringList categories; - QStringList::ConstIterator it; - for( it = categoryIds.begin(); it != categoryIds.end(); ++it ) { - QString cate = category( *it ); - if ( oldCategories ) { - if ( ! oldCategories->contains( cate ) ) - oldCategories->append( cate ); + if(dt.time().isValid()){ + const QTime& time = dt.time(); + timestr.sprintf("T%02d%02d%02d", + time.hour(), time.minute(), time.second()); } - categories.append(cate ); + return datestr + timestr; } - return categories; + QDate datefromGSM ( GSM_DateTime* dtp ) { + return QDate ( dtp->Year, dtp->Month, dtp->Day ); } - - private: - QString mProfileName ; - Calendar *mCalendar; - QStringList * oldCategories; - static QString category( const QString &id ) + QString getCategory( GSM_CalendarEntry* Note) { - QMap<QString,QString>::ConstIterator it = mCategoriesMap.find( id ); - if ( it == mCategoriesMap.end() ) return id; - else return *it; + QString CATEGORY; + switch (Note->Type) { + case GSM_CAL_REMINDER : CATEGORY = QString("Reminder"); break; + case GSM_CAL_CALL : CATEGORY = QString("Call"); break; + case GSM_CAL_MEETING : CATEGORY = QString("Meeting"); break; + case GSM_CAL_BIRTHDAY : CATEGORY = QString("Birthday"); break; + case GSM_CAL_MEMO : CATEGORY = QString("Memo"); break; + case GSM_CAL_TRAVEL : CATEGORY = QString("Travel"); break; + case GSM_CAL_VACATION : CATEGORY = QString("Vacation"); break; + case GSM_CAL_ALARM : CATEGORY = QString("Alarm"); break; + case GSM_CAL_DAILY_ALARM : CATEGORY = QString("Daily alarm"); break; + case GSM_CAL_T_ATHL : CATEGORY = QString("Training/Athletism"); break; + case GSM_CAL_T_BALL : CATEGORY = QString("Training/Ball Games"); break; + case GSM_CAL_T_CYCL : CATEGORY = QString("Training/Cycling"); break; + case GSM_CAL_T_BUDO : CATEGORY = QString("Training/Budo"); break; + case GSM_CAL_T_DANC : CATEGORY = QString("Training/Dance"); break; + case GSM_CAL_T_EXTR : CATEGORY = QString("Training/Extreme Sports"); break; + case GSM_CAL_T_FOOT : CATEGORY = QString("Training/Football"); break; + case GSM_CAL_T_GOLF : CATEGORY = QString("Training/Golf"); break; + case GSM_CAL_T_GYM : CATEGORY = QString("Training/Gym"); break; + case GSM_CAL_T_HORS : CATEGORY = QString("Training/Horse Races"); break; + case GSM_CAL_T_HOCK : CATEGORY = QString("Training/Hockey"); break; + case GSM_CAL_T_RACE : CATEGORY = QString("Training/Races"); break; + case GSM_CAL_T_RUGB : CATEGORY = QString("Training/Rugby"); break; + case GSM_CAL_T_SAIL : CATEGORY = QString("Training/Sailing"); break; + case GSM_CAL_T_STRE : CATEGORY = QString("Training/Street Games"); break; + case GSM_CAL_T_SWIM : CATEGORY = QString("Training/Swimming"); break; + case GSM_CAL_T_TENN : CATEGORY = QString("Training/Tennis"); break; + case GSM_CAL_T_TRAV : CATEGORY = QString("Training/Travels"); break; + case GSM_CAL_T_WINT : CATEGORY = QString("Training/Winter Games"); break; + default : CATEGORY = QString(""); } - static void setCategory( const QString &id, const QString &name ) - { - mCategoriesMap.insert( id, name ); + return CATEGORY; } - static QMap<QString,QString> mCategoriesMap; +protected: +private: + Calendar *mCalendar; + QString mProfileName ; }; -QMap<QString,QString> PhoneParser::mCategoriesMap; PhoneFormat::PhoneFormat() { - mCategories = 0; + ; } PhoneFormat::~PhoneFormat() @@ -549,12 +652,7 @@ static char *cp; {break;} } - - - int error=GSM_InitConnection(&s,3); - - qDebug(" init %d %d", error, ERR_NONE); if ( error != ERR_NONE ) return false; @@ -565,134 +663,35 @@ static char *cp; Phone=s.Phone.Functions; bool gshutdown = false; PhoneParser handler( calendar, profileName ); - //handler.setCategoriesList( mCategories ); int ccc = 0; while (!gshutdown && ccc++ < 10 ) { - qDebug("count %d ", ccc); + qDebug("readEvent %d ", ccc); error=Phone->GetNextCalendar(&s,¬e,refresh); if (error == ERR_EMPTY) break; - handler.startElement( existingCal, ¬e, "Event" ); + handler.readEvent( existingCal, ¬e ); } - error=GSM_TerminateConnection(&s); -#if 0 - bool debug = DEBUGMODE; - //debug = true; - QString text; - QString codec = "utf8"; - QLabel status ( i18n("Reading events ..."), 0 ); - - int w = status.sizeHint().width()+20 ; - if ( w < 200 ) w = 200; - int h = status.sizeHint().height()+20 ; - int dw = QApplication::desktop()->width(); - int dh = QApplication::desktop()->height(); - status.setCaption(i18n("Reading DTM Data") ); - status.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); - status.show(); - status.raise(); - qApp->processEvents(); - QString fileName; - if ( ! debug ) { - fileName = "/tmp/kopitempout"; - QString command ="db2file datebook -r -c "+ codec + " > " + fileName; - system ( command.latin1() ); - } else { - fileName = "/tmp/events.txt"; - - } - QFile file( fileName ); - if (!file.open( IO_ReadOnly ) ) { - return false; + bool start = true; + GSM_ToDoEntry ToDo; + int ccc = 0; + while (!gshutdown) { + error = Phone->GetNextToDo(&s, &ToDo, start); + if (error == ERR_EMPTY) break; + start = false; + qDebug("readTodo %d ", ++ccc); + handler.readTodo( existingCal, &ToDo, &s); } - QTextStream ts( &file ); - ts.setCodec( QTextCodec::codecForName("utf8") ); - text = ts.read(); - file.close(); - status.setText( i18n("Processing events ...") ); - status.raise(); - qApp->processEvents(); - fromString2Cal( calendar, existngCal, text, "Event" ); - status.setText( i18n("Reading todos ...") ); - qApp->processEvents(); - if ( ! debug ) { - fileName = "/tmp/kopitempout"; - QString command = "db2file todo -r -c " + codec+ " > " + fileName; - system ( command.latin1() ); - } else { - fileName = "/tmp/todo.txt"; - } - file.setName( fileName ); - if (!file.open( IO_ReadOnly ) ) { - return false; - } - ts.setDevice( &file ); - text = ts.read(); - file.close(); + error=GSM_TerminateConnection(&s); - status.setText( i18n("Processing todos ...") ); - status.raise(); - qApp->processEvents(); - fromString2Cal( calendar, existngCal, text, "Todo" ); -#endif return true; } -int PhoneFormat::getNumFromRecord( QString answer, Incidence* inc ) -{ - int retval = -1; - QStringList templist; - QString tempString; - int start = 0; - int len = answer.length(); - int end = answer.find ("\n",start)+1; - bool ok = true; - start = end; - int ccc = 0; - while ( start > 0 ) { - templist.clear(); - ok = true; - int loopCount = 0; - while ( ok ) { - ++loopCount; - if ( loopCount > 25 ) { - qDebug("KO: Error in while loop"); - ok = false; - start = 0; - break; - } - if ( ok ) - tempString = getPart( answer, ok, start ); - if ( start >= len || start == 0 ) { - start = 0; - ok = false; - } - if ( tempString.right(1) =="\n" ) - tempString = tempString.left( tempString.length()-1); - templist.append( tempString ); - } - ++ccc; - if ( ccc == 2 && loopCount < 25 ) { - start = 0; - bool ok; - int newnum = templist[0].toInt( &ok ); - if ( ok && newnum > 0) { - retval = newnum; - //inc->setZaurusId( newnum ); - //inc->setZaurusUid( getCsum( templist ) ); - //inc->setZaurusStat( -4 ); - } - } - } - //qDebug("getNumFromRecord returning : %d ", retval); - return retval; -} bool PhoneFormat::save( Calendar *calendar) { - +#if 0 QLabel status ( i18n("Processing/adding events ..."), 0 ); int w = status.sizeHint().width()+20 ; if ( w < 200 ) w = 200; @@ -883,10 +882,10 @@ bool PhoneFormat::save( Calendar *calendar) system ( command.latin1() ); // qDebug("command %s file :\n%s ", command.latin1(), deleteString.latin1()); } - +#endif return true; } -QString PhoneFormat::dtToString( const QDateTime& dti, bool useTZ ) +QString PhoneFormat::dtToGSM( const QDateTime& dti, bool useTZ ) { QString datestr; QString timestr; @@ -1127,391 +1126,13 @@ QString PhoneFormat::getTodoString( Todo* todo ) #endif return QString(); } -QString PhoneFormat::getPart( const QString & text, bool &ok, int &start ) -{ - //qDebug("start %d ", start); - - QString retval =""; - if ( text.at(start) == '"' ) { - if ( text.mid( start,2) == "\"\"" && !( text.mid( start+2,1) == "\"")) { - start = start +2; - if ( text.mid( start,1) == "," ) { - start += 1; - } - retval = ""; - if ( text.mid( start,1) == "\n" ) { - start += 1; - ok = false; - } - return retval; - } - int hk = start+1; - hk = text.find ('"',hk); - while ( text.at(hk+1) == '"' ) - hk = text.find ('"',hk+2); - retval = text.mid( start+1, hk-start-1); - start = hk+1; - retval.replace( QRegExp("\"\""), "\""); - if ( text.mid( start,1) == "," ) { - start += 1; - } - if ( text.mid( start,1) == "\n" ) { - start += 1; - ok = false; - } - //qDebug("retval***%s*** ",retval.latin1() ); - return retval; - - } else { - int nl = text.find ("\n",start); - int kom = text.find (',',start); - if ( kom < nl ) { - // qDebug("kom < nl %d ", kom); - retval = text.mid(start, kom-start); - start = kom+1; - return retval; - } else { - if ( nl == kom ) { - // qDebug(" nl == kom "); - start = 0; - ok = false; - return "0"; - } - // qDebug(" nl < kom ", nl); - retval = text.mid( start, nl-start); - ok = false; - start = nl+1; - return retval; - } - } -} -bool PhoneFormat::fromString( Calendar *calendar, const QString & text) -{ - return false; -} -bool PhoneFormat::fromString2Cal( Calendar *calendar,Calendar *existingCalendar, GSM_StateMachine* s, const QString & type) -{ -#if 0 - GSM_Phone_Functions *Phone; - - GSM_CalendarEntry note; - GSM_CalendarEntry* Note; - bool refresh = true; - - Phone=s->Phone.Functions; - bool gshutdown = false; - PhoneParser handler( calendar ); - //handler.setCategoriesList( mCategories ); - QStringList templist; - QString tempString; - int start = 0; - int error; - int ccc = 0; - while (!gshutdown && ccc++ < 10 ) { - QString CARDID,CATEGORY,DSRP,PLCE,MEM1,TIM1,TIM2,ADAY,ARON,ARMN,ARSD,RTYP,RFRQ,RPOS,RDYS,REND,REDT,ALSD,ALED,MDAY; - templist.clear(); - qDebug("count %d ", ccc); - error=Phone->GetNextCalendar(s,¬e,refresh); - if (error == ERR_EMPTY) break; - - Note = ¬e; -//CARDID,CATEGORY,DSRP,PLCE,MEM1,TIM1,TIM2,ADAY,ARON,ARMN,ARSD,RTYP,RFRQ,RPOS,RDYS,REND,REDT,ALSD,ALED,MDAY -// 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 - -//ARSD silentalarm = 0 -// 11 RTYP 225 no /0 dialy/ 1 weekly/ 3 month by date/ 2 month by day(pos)/ yearly -// 12 RFRQ -// 13 RPOS pos = 4. monday in month -// 14 RDYS days: 1 mon/ 2 tue .. 64 sun -// 15 REND 0 = no end/ 1 = end -// 16 REDT rec end dt -//ALSD -//ALED -//MDAY - - CARDID = QString::number( Note->Location ); // 0 - - - int i_age = 0,i; - GSM_DateTime Alarm,DateTime; - GSM_DateTime* dtp; - GSM_MemoryEntry entry; - unsigned char *name; - - bool repeating = false; - int repeat_dayofweek = -1; - int repeat_day = -1; - int repeat_weekofmonth = -1; - int repeat_month = -1; - int repeat_frequency = -1; - GSM_DateTime repeat_startdate = {0,0,0,0,0,0,0}; - GSM_DateTime repeat_stopdate = {0,0,0,0,0,0,0}; - - Alarm.Year = 0; - - repeating = false; - repeat_dayofweek = -1; - repeat_day = -1; - repeat_weekofmonth = -1; - repeat_month = -1; - repeat_frequency = -1; - repeat_startdate.Day = 0; - repeat_stopdate.Day = 0; - - - switch (Note->Type) { - case GSM_CAL_REMINDER : CATEGORY = QString("Reminder"); break; - case GSM_CAL_CALL : CATEGORY = QString("Call"); break; - case GSM_CAL_MEETING : CATEGORY = QString("Meeting"); break; - case GSM_CAL_BIRTHDAY : CATEGORY = QString("Birthday"); break; - case GSM_CAL_MEMO : CATEGORY = QString("Memo"); break; - case GSM_CAL_TRAVEL : CATEGORY = QString("Travel"); break; - case GSM_CAL_VACATION : CATEGORY = QString("Vacation"); break; - case GSM_CAL_ALARM : CATEGORY = QString("Alarm"); break; - case GSM_CAL_DAILY_ALARM : CATEGORY = QString("Daily alarm"); break; - case GSM_CAL_T_ATHL : CATEGORY = QString("Training/Athletism"); break; - case GSM_CAL_T_BALL : CATEGORY = QString("Training/Ball Games"); break; - case GSM_CAL_T_CYCL : CATEGORY = QString("Training/Cycling"); break; - case GSM_CAL_T_BUDO : CATEGORY = QString("Training/Budo"); break; - case GSM_CAL_T_DANC : CATEGORY = QString("Training/Dance"); break; - case GSM_CAL_T_EXTR : CATEGORY = QString("Training/Extreme Sports"); break; - case GSM_CAL_T_FOOT : CATEGORY = QString("Training/Football"); break; - case GSM_CAL_T_GOLF : CATEGORY = QString("Training/Golf"); break; - case GSM_CAL_T_GYM : CATEGORY = QString("Training/Gym"); break; - case GSM_CAL_T_HORS : CATEGORY = QString("Training/Horse Races"); break; - case GSM_CAL_T_HOCK : CATEGORY = QString("Training/Hockey"); break; - case GSM_CAL_T_RACE : CATEGORY = QString("Training/Races"); break; - case GSM_CAL_T_RUGB : CATEGORY = QString("Training/Rugby"); break; - case GSM_CAL_T_SAIL : CATEGORY = QString("Training/Sailing"); break; - case GSM_CAL_T_STRE : CATEGORY = QString("Training/Street Games"); break; - case GSM_CAL_T_SWIM : CATEGORY = QString("Training/Swimming"); break; - case GSM_CAL_T_TENN : CATEGORY = QString("Training/Tennis"); break; - case GSM_CAL_T_TRAV : CATEGORY = QString("Training/Travels"); break; - case GSM_CAL_T_WINT : CATEGORY = QString("Training/Winter Games"); break; - default : CATEGORY = QString(""); - } -//CARDID,CATEGORY,DSRP,PLCE,MEM1,TIM1,TIM2,ADAY,ARON,ARMN,ARSD,RTYP,RFRQ,RPOS,RDYS,REND,REDT,ALSD,ALED,MDAY -// 0x 1x 2x 3x 4x 5x 6x 7x 8x 9x 10? 11 12 13 14 15 16 17x 18x 19? - - MEM1 = ""; - -#if 0 - - if ( attList[7] == "1" ) { - event->setDtStart( QDateTime(fromString( attList[17]+"000000", false ).date(),QTime(0,0,0 ) )); - event->setDtEnd( QDateTime(fromString( attList[18]+"000000", false ).date(),QTime(0,0,0 ))); - event->setFloats( true ); - } else { - event->setFloats( false ); - event->setDtStart( fromString( attList[5] ) ); - event->setDtEnd( fromString( attList[6] )); - } - - - -typedef struct { - /** - * The difference between local time and GMT in hours - */ - int Timezone; - - unsigned int Second; - unsigned int Minute; - unsigned int Hour; - - unsigned int Day; - /** - * January = 1, February = 2, etc. - */ - unsigned int Month; - /** - * Complete year number. Not 03, but 2003 - */ - unsigned int Year; -} GSM_DateTime; - - if(dt.date().isValid()){ - const QDate& date = dt.date(); - datestr.sprintf("%04d%02d%02d", - date.year(), date.month(), date.day()); - } - if(dt.time().isValid()){ - const QTime& time = dt.time(); - timestr.sprintf("T%02d%02d%02d", - time.hour(), time.minute(), time.second()); - } - return datestr + timestr; - - - - -#endif - - - ADAY = "0"; - ARON = "1"; // 1 == disabled - ARMN = "0"; //alarm offset in minutes - - for (i=0;i<Note->EntriesNum;i++) { - - qDebug(" for "); - switch (Note->Entries[i].EntryType) { - case CAL_START_DATETIME: - dtp = &Note->Entries[i].Date ; - - qDebug("hour: %d ", dtp->Hour); - if ( dtp->Hour == -1 ) { - ADAY = "1"; - ALSD.sprintf("%04d%02d%02d",dtp->Year, dtp->Month, dtp->Day ); - TIM1.sprintf("%04d%02d%02dT000000",dtp->Year, dtp->Month, dtp->Day ); - } else { - TIM1.sprintf("%04d%02d%02dT%02d%02d%02d",dtp->Year, dtp->Month, dtp->Day, dtp->Hour - dtp->Timezone, dtp->Minute, dtp->Second ); - - } - ////printmsg("Start : %s\n",OSDateTime(Note->Entries[i].Date,false)); - // memcpy(&DateTime,&Note->Entries[i].Date,sizeof(GSM_DateTime)); - break; - case CAL_END_DATETIME: - dtp = &Note->Entries[i].Date ; - qDebug("hour2: %d ", dtp->Hour); - if ( dtp->Hour == -1 ) { - ADAY = "1"; - ALED.sprintf("%04d%02d%02d",dtp->Year, dtp->Month, dtp->Day ); - TIM2.sprintf("%04d%02d%02dT000000",dtp->Year, dtp->Month, dtp->Day ); - } else { - TIM2.sprintf("%04d%02d%02dT%02d%02d%02d",dtp->Year, dtp->Month, dtp->Day, dtp->Hour - dtp->Timezone, dtp->Minute, dtp->Second ); - - } - //printmsg("Stop : %s\n",OSDateTime(Note->Entries[i].Date,false)); - //memcpy(&DateTime,&Note->Entries[i].Date,sizeof(GSM_DateTime)); - break; - case CAL_ALARM_DATETIME: - ARON = "0"; - dtp = &Note->Entries[i].Date ; - ARMN.sprintf("%04d%02d%02dT%02d%02d%02d",dtp->Year, dtp->Month, dtp->Day, dtp->Hour - dtp->Timezone, dtp->Minute, dtp->Second ); - //printmsg("Tone alarm : %s\n",OSDateTime(Note->Entries[i].Date,false)); - memcpy(&Alarm,&Note->Entries[i].Date,sizeof(GSM_DateTime)); - break; - case CAL_SILENT_ALARM_DATETIME: - ARON = "0"; - dtp = &Note->Entries[i].Date ; - ARMN.sprintf("%04d%02d%02dT%02d%02d%02d",dtp->Year, dtp->Month, dtp->Day, dtp->Hour - dtp->Timezone, dtp->Minute, dtp->Second ); - //printmsg("Silent alarm : %s\n",OSDateTime(Note->Entries[i].Date,false)); - //memcpy(&Alarm,&Note->Entries[i].Date,sizeof(GSM_DateTime)); - break; - case CAL_RECURRANCE: - //printmsg("Repeat : %d day%s\n",Note->Entries[i].Number/24,((Note->Entries[i].Number/24)>1) ? "s":"" ); - break; - case CAL_TEXT: - DSRP = QString ( (const char*) Note->Entries[i].Text ); - break; - case CAL_LOCATION: - PLCE = QString ((const char*) Note->Entries[i].Text ); - break; - case CAL_PHONE: - //printmsg("Phone : \"%s\"\n",DecodeUnicodeConsole(Note->Entries[i].Text)); - break; - case CAL_PRIVATE: - //printmsg("Private : %s\n",Note->Entries[i].Number == 1 ? "Yes" : "No"); - break; - case CAL_CONTACTID: -#if 0 - entry.Location = Note->Entries[i].Number; - entry.MemoryType = MEM_ME; - error=Phone->GetMemory(&s, &entry); - if (error == ERR_NONE) { - name = GSM_PhonebookGetEntryName(&entry); - if (name != NULL) { - //printmsg("Contact ID : \"%s\" (%d)\n", DecodeUnicodeConsole(name), Note->Entries[i].Number); - } else { - //printmsg("Contact ID : %d\n",Note->Entries[i].Number); - } - } else { - //printmsg("Contact ID : %d\n",Note->Entries[i].Number); - } -#endif - break; - case CAL_REPEAT_DAYOFWEEK: - repeat_dayofweek = Note->Entries[i].Number; - repeating = true; - break; - case CAL_REPEAT_DAY: - repeat_day = Note->Entries[i].Number; - repeating = true; - break; - case CAL_REPEAT_WEEKOFMONTH: - repeat_weekofmonth = Note->Entries[i].Number; - repeating = true; - break; - case CAL_REPEAT_MONTH: - repeat_month = Note->Entries[i].Number; - repeating = true; - break; - case CAL_REPEAT_FREQUENCY: - repeat_frequency = Note->Entries[i].Number; - repeating = true; - break; - case CAL_REPEAT_STARTDATE: - repeat_startdate = Note->Entries[i].Date; - repeating = true; - break; - case CAL_REPEAT_STOPDATE: - repeat_stopdate = Note->Entries[i].Date; - repeating = true; - break; - } - } - - if ( ARON == "0" ) { - QDateTime start,alarm; - start = handler.fromString( TIM1 ); - alarm = handler.fromString( ARMN ); - int min = alarm.secsTo ( start )/60; - ARMN = QString::number ( min ); - } - - templist.clear(); - templist << CARDID << CATEGORY << DSRP << PLCE << MEM1 << TIM1 << TIM2 << ADAY << ARON << ARMN << ARSD << RTYP << RFRQ << RPOS << RDYS << REND << REDT << ALSD << ALED << MDAY; - handler.startElement( existingCalendar, templist, type ); - } - - -#endif -#if 0 - // qDebug("test %s ", text.latin1()); - QStringList templist; - QString tempString; - int start = 0; - int len = text.length(); - int end = text.find ("\n",start)+1; - bool ok = true; - start = end; - PhoneParser handler( calendar ); - handler.setCategoriesList( mCategories ); - while ( start > 0 ) { - templist.clear(); - ok = true; - while ( ok ) { - tempString = getPart( text, ok, start ); - if ( start >= len || start == 0 ) { - start = 0; - ok = false; - } - if ( tempString.right(1) =="\n" ) - tempString = tempString.left( tempString.length()-1); - //if ( ok ) - templist.append( tempString ); - //qDebug("%d ---%s---", templist.count(),tempString.latin1() ); - } - handler.startElement( existingCalendar, templist, type ); - } -#endif - return false; -} - QString PhoneFormat::toString( Calendar * ) { return QString::null; } +bool PhoneFormat::fromString( Calendar *calendar, const QString & text) +{ + return false; +} diff --git a/libkcal/phoneformat.h b/libkcal/phoneformat.h index 4da38c8..8d4e200 100644 --- a/libkcal/phoneformat.h +++ b/libkcal/phoneformat.h @@ -44,8 +44,6 @@ class PhoneFormat : public QObject { bool load( Calendar * ,Calendar *, QString profileName, QString device,QString connection, QString model ); bool save( Calendar * ); - void setCategoriesList ( QStringList * cat ){ mCategories = cat; } - bool fromString2Cal( Calendar *, Calendar *, GSM_StateMachine* s , const QString & ); bool fromString( Calendar *, const QString & ); QString toString( Calendar * ); static ulong getCsum( const QStringList & ); @@ -53,11 +51,7 @@ class PhoneFormat : public QObject { private: QString getEventString( Event* ); QString getTodoString( Todo* ); - QString dtToString( const QDateTime& dt, bool useTZ = true ); - - QStringList *mCategories; - int getNumFromRecord( QString answer,Incidence* inc ) ; - QString getPart( const QString & text, bool &ok, int &start ); + QString dtToGSM( const QDateTime& dt, bool useTZ = true ); QString mProfileName; }; |