author | ulf69 <ulf69> | 2004-09-29 06:14:36 (UTC) |
---|---|---|
committer | ulf69 <ulf69> | 2004-09-29 06:14:36 (UTC) |
commit | 72b990edf0191c2e86204308ce2cac07120284bf (patch) (unidiff) | |
tree | 67840eda5450e7b3bc19fd181b48e5c981df96b3 | |
parent | f7810320ed36a03c96d00436f6b589b9b5ca8c30 (diff) | |
download | kdepimpi-72b990edf0191c2e86204308ce2cac07120284bf.zip kdepimpi-72b990edf0191c2e86204308ce2cac07120284bf.tar.gz kdepimpi-72b990edf0191c2e86204308ce2cac07120284bf.tar.bz2 |
support for ISODate parsing
-rw-r--r-- | microkde/kdecore/klocale.cpp | 44 | ||||
-rw-r--r-- | microkde/kdecore/klocale.h | 1 |
2 files changed, 34 insertions, 11 deletions
diff --git a/microkde/kdecore/klocale.cpp b/microkde/kdecore/klocale.cpp index 7bd8a70..17031c7 100644 --- a/microkde/kdecore/klocale.cpp +++ b/microkde/kdecore/klocale.cpp | |||
@@ -570,36 +570,59 @@ QTime KLocale::readTime(const QString &intstr, bool seconds, bool *ok) const | |||
570 | 570 | ||
571 | if (ok) *ok = true; | 571 | if (ok) *ok = true; |
572 | return QTime(hour, minute, second); | 572 | return QTime(hour, minute, second); |
573 | 573 | ||
574 | error: | 574 | error: |
575 | if (ok) *ok = false; | 575 | if (ok) *ok = false; |
576 | return QTime(-1, -1, -1); // return invalid date if it didn't work | 576 | return QTime(-1, -1, -1); // return invalid date if it didn't work |
577 | // This will be removed in the near future, since it gives a warning on stderr. | 577 | // This will be removed in the near future, since it gives a warning on stderr. |
578 | // The presence of the bool* (since KDE-3.0) removes the need for an invalid QTime. | 578 | // The presence of the bool* (since KDE-3.0) removes the need for an invalid QTime. |
579 | } | 579 | } |
580 | 580 | ||
581 | QDateTime KLocale::readDateTime(const QString &intstr, | 581 | QDateTime KLocale::readDateTime(const QString &intstr, |
582 | bool shortFormat, | ||
583 | bool includeSeconds, | ||
584 | IntDateFormat intIntDateFormat, | 582 | IntDateFormat intIntDateFormat, |
585 | bool* ok) const | 583 | bool* ok) const |
586 | { | 584 | { |
587 | bool ok1, ok2; | 585 | bool ok1, ok2; |
588 | 586 | ||
589 | QDate m_date = readDate(date, &ok1); | 587 | // AT the moment we can not read any other format then ISODate |
590 | QTime m_time = KGlobal::locale()->readTime(time, &ok2); | 588 | if ( intIntDateFormat != ISODate ) |
591 | if ((ok1 == false) || (ok2 == false)) | 589 | { |
592 | qDebug("Serializer::extractMeta invalid date or time !!!!!!!!!!!!!"); | 590 | qDebug("KLocale::readDateTime, only ISODate is supported."); |
591 | return QDateTime(); | ||
592 | } | ||
593 | |||
594 | int pos = intstr.find("T"); | ||
595 | QString date = intstr.left(pos); | ||
596 | QString time = intstr.mid(pos+1); | ||
593 | 597 | ||
598 | QString dformat = dateFormat(intIntDateFormat); | ||
599 | QString tformat = timeFormat(intIntDateFormat); | ||
600 | |||
601 | QDate m_date = readDate(date, dformat, &ok1); | ||
602 | QTime m_time = readTime(time, tformat, &ok2); | ||
603 | |||
604 | if (ok) | ||
605 | { | ||
606 | if ((ok1 == false) || (ok2 == false)) | ||
607 | *ok = false; | ||
608 | else | ||
609 | *ok = true; | ||
610 | } | ||
611 | QDateTime m_dt; | ||
612 | m_dt.setDate(m_date); | ||
613 | m_dt.setTime(m_time); | ||
614 | |||
615 | qDebug("KLocale::readDateTime() transformed %s into %s (%s), %s (%s) : err1=%i, err2=%i", intstr.latin1(), date.latin1(), dformat.latin1(), time.latin1(), tformat.latin1(), ok1, ok2); | ||
616 | return m_dt; | ||
594 | } | 617 | } |
595 | 618 | ||
596 | 619 | ||
597 | bool KLocale::use12Clock() const | 620 | bool KLocale::use12Clock() const |
598 | { | 621 | { |
599 | return !mHourF24Format ;; | 622 | return !mHourF24Format ;; |
600 | } | 623 | } |
601 | 624 | ||
602 | bool KLocale::weekStartsMonday() const | 625 | bool KLocale::weekStartsMonday() const |
603 | { | 626 | { |
604 | return mWeekStartsMonday; | 627 | return mWeekStartsMonday; |
605 | } | 628 | } |
@@ -677,39 +700,38 @@ QString KLocale::monthName(int i,bool shortName) const | |||
677 | return QString::null; | 700 | return QString::null; |
678 | } | 701 | } |
679 | 702 | ||
680 | QString KLocale::country() const | 703 | QString KLocale::country() const |
681 | { | 704 | { |
682 | return QString::null; | 705 | return QString::null; |
683 | } | 706 | } |
684 | 707 | ||
685 | QString KLocale::dateFormat(IntDateFormat intIntDateFormat) const | 708 | QString KLocale::dateFormat(IntDateFormat intIntDateFormat) const |
686 | { | 709 | { |
687 | const IntDateFormat dformat = (intIntDateFormat == Undefined)?mIntDateFormat:intIntDateFormat; | 710 | const IntDateFormat dformat = (intIntDateFormat == Undefined)?mIntDateFormat:intIntDateFormat; |
688 | 711 | ||
712 | if ( dformat == ISODate ) | ||
713 | return "%Y-%m-%d"; | ||
714 | |||
689 | if ( QApplication::desktop()->width() < 480 ) { | 715 | if ( QApplication::desktop()->width() < 480 ) { |
690 | if ( dformat == Default ) | 716 | if ( dformat == Default ) |
691 | return "%a %d %b %Y"; | 717 | return "%a %d %b %Y"; |
692 | else if ( dformat == Format1 ) | 718 | else if ( dformat == Format1 ) |
693 | return "%a %b %d %Y"; | 719 | return "%a %b %d %Y"; |
694 | else if ( dformat == ISODate ) | ||
695 | return "%a %Y %b %d"; | ||
696 | } else { | 720 | } else { |
697 | |||
698 | if ( dformat == Default ) | 721 | if ( dformat == Default ) |
699 | return "%A %d %B %Y"; | 722 | return "%A %d %B %Y"; |
700 | else if ( dformat == Format1 ) | 723 | else if ( dformat == Format1 ) |
701 | return "%A %B %d %Y"; | 724 | return "%A %B %d %Y"; |
702 | else if ( dformat == ISODate ) | 725 | |
703 | return "%A %Y %B %d"; | ||
704 | } | 726 | } |
705 | return mDateFormat ; | 727 | return mDateFormat ; |
706 | } | 728 | } |
707 | 729 | ||
708 | QString KLocale::dateFormatShort(IntDateFormat intIntDateFormat) const | 730 | QString KLocale::dateFormatShort(IntDateFormat intIntDateFormat) const |
709 | { | 731 | { |
710 | const IntDateFormat dformat = (intIntDateFormat == Undefined)?mIntDateFormat:intIntDateFormat; | 732 | const IntDateFormat dformat = (intIntDateFormat == Undefined)?mIntDateFormat:intIntDateFormat; |
711 | 733 | ||
712 | if ( dformat == Default ) | 734 | if ( dformat == Default ) |
713 | return "%d.%m.%Y"; | 735 | return "%d.%m.%Y"; |
714 | else if ( dformat == Format1 ) | 736 | else if ( dformat == Format1 ) |
715 | return "%m.%d.%Y"; | 737 | return "%m.%d.%Y"; |
diff --git a/microkde/kdecore/klocale.h b/microkde/kdecore/klocale.h index 153b12a..949301a 100644 --- a/microkde/kdecore/klocale.h +++ b/microkde/kdecore/klocale.h | |||
@@ -44,24 +44,25 @@ class KLocale | |||
44 | enum IntDateFormat { Undefined=-1, Default=0, Format1=1, ISODate=2, Userdefined=3 }; | 44 | enum IntDateFormat { Undefined=-1, Default=0, Format1=1, ISODate=2, Userdefined=3 }; |
45 | 45 | ||
46 | QString formatDate(const QDate &pDate, bool shortFormat = false, IntDateFormat intIntDateFormat = Undefined) const; | 46 | QString formatDate(const QDate &pDate, bool shortFormat = false, IntDateFormat intIntDateFormat = Undefined) const; |
47 | QString formatTime(const QTime &pTime, bool includeSecs = false, IntDateFormat intIntDateFormat = Undefined) const; | 47 | QString formatTime(const QTime &pTime, bool includeSecs = false, IntDateFormat intIntDateFormat = Undefined) const; |
48 | QString formatDateTime(const QDateTime &pDateTime, IntDateFormat intIntDateFormat = Undefined) const; | 48 | QString formatDateTime(const QDateTime &pDateTime, IntDateFormat intIntDateFormat = Undefined) const; |
49 | QString formatDateTime(const QDateTime &pDateTime, | 49 | QString formatDateTime(const QDateTime &pDateTime, |
50 | bool shortFormat, | 50 | bool shortFormat, |
51 | bool includeSecs = false, IntDateFormat intIntDateFormat = Undefined) const; | 51 | bool includeSecs = false, IntDateFormat intIntDateFormat = Undefined) const; |
52 | 52 | ||
53 | QDate readDate(const QString &str, bool* ok = 0) const; | 53 | QDate readDate(const QString &str, bool* ok = 0) const; |
54 | QDate readDate( const QString &intstr, const QString &fmt, bool* ok = 0) const; | 54 | QDate readDate( const QString &intstr, const QString &fmt, bool* ok = 0) const; |
55 | QTime readTime(const QString &str, bool* ok = 0) const; | 55 | QTime readTime(const QString &str, bool* ok = 0) const; |
56 | QDateTime readDateTime(const QString &intstr, IntDateFormat intIntDateFormat, bool* ok) const; | ||
56 | 57 | ||
57 | bool use12Clock() const; | 58 | bool use12Clock() const; |
58 | bool weekStartsMonday() const; | 59 | bool weekStartsMonday() const; |
59 | int weekStartDay() const; | 60 | int weekStartDay() const; |
60 | 61 | ||
61 | QString weekDayName(int,bool=false) const; | 62 | QString weekDayName(int,bool=false) const; |
62 | QString monthName(int,bool=false) const; | 63 | QString monthName(int,bool=false) const; |
63 | 64 | ||
64 | QString country() const; | 65 | QString country() const; |
65 | 66 | ||
66 | QString dateFormat(IntDateFormat intIntDateFormat = Undefined) const; | 67 | QString dateFormat(IntDateFormat intIntDateFormat = Undefined) const; |
67 | QString dateFormatShort(IntDateFormat intIntDateFormat = Undefined) const; | 68 | QString dateFormatShort(IntDateFormat intIntDateFormat = Undefined) const; |