author | schurig <schurig> | 2003-06-10 16:35:43 (UTC) |
---|---|---|
committer | schurig <schurig> | 2003-06-10 16:35:43 (UTC) |
commit | d2f78d2aba17a491739d10bd73f6fce033849537 (patch) (unidiff) | |
tree | 0d8e5683afaa6da476001e00fc6db2ebc5c1a0df /libopie/odevice.cpp | |
parent | 8ffea5d37080bd173d55a458296c1fc461a54d13 (diff) | |
download | opie-d2f78d2aba17a491739d10bd73f6fce033849537.zip opie-d2f78d2aba17a491739d10bd73f6fce033849537.tar.gz opie-d2f78d2aba17a491739d10bd73f6fce033849537.tar.bz2 |
renamed frequency access methods
-rw-r--r-- | libopie/odevice.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index 4c33a0e..d6e6892 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -522,526 +522,526 @@ bool ODevice::suspend ( ) | |||
522 | ::gettimeofday ( &tvn, 0 ); | 522 | ::gettimeofday ( &tvn, 0 ); |
523 | } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); | 523 | } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); |
524 | } | 524 | } |
525 | 525 | ||
526 | return res; | 526 | return res; |
527 | } | 527 | } |
528 | 528 | ||
529 | //#include <linux/fb.h> better not rely on kernel headers in userspace ... | 529 | //#include <linux/fb.h> better not rely on kernel headers in userspace ... |
530 | 530 | ||
531 | #define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611 | 531 | #define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611 |
532 | 532 | ||
533 | /* VESA Blanking Levels */ | 533 | /* VESA Blanking Levels */ |
534 | #define VESA_NO_BLANKING 0 | 534 | #define VESA_NO_BLANKING 0 |
535 | #define VESA_VSYNC_SUSPEND 1 | 535 | #define VESA_VSYNC_SUSPEND 1 |
536 | #define VESA_HSYNC_SUSPEND 2 | 536 | #define VESA_HSYNC_SUSPEND 2 |
537 | #define VESA_POWERDOWN 3 | 537 | #define VESA_POWERDOWN 3 |
538 | 538 | ||
539 | /** | 539 | /** |
540 | * This sets the display on or off | 540 | * This sets the display on or off |
541 | */ | 541 | */ |
542 | bool ODevice::setDisplayStatus ( bool on ) | 542 | bool ODevice::setDisplayStatus ( bool on ) |
543 | { | 543 | { |
544 | qDebug("ODevice::setDisplayStatus(%d)", on); | 544 | qDebug("ODevice::setDisplayStatus(%d)", on); |
545 | 545 | ||
546 | if ( d-> m_model == Model_Unknown ) | 546 | if ( d-> m_model == Model_Unknown ) |
547 | return false; | 547 | return false; |
548 | 548 | ||
549 | bool res = false; | 549 | bool res = false; |
550 | int fd; | 550 | int fd; |
551 | 551 | ||
552 | if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) { | 552 | if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) { |
553 | res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 ); | 553 | res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 ); |
554 | ::close ( fd ); | 554 | ::close ( fd ); |
555 | } | 555 | } |
556 | return res; | 556 | return res; |
557 | } | 557 | } |
558 | 558 | ||
559 | /** | 559 | /** |
560 | * This sets the display brightness | 560 | * This sets the display brightness |
561 | * | 561 | * |
562 | * @param p The brightness to be set on a scale from 0 to 255 | 562 | * @param p The brightness to be set on a scale from 0 to 255 |
563 | * @return success or failure | 563 | * @return success or failure |
564 | */ | 564 | */ |
565 | bool ODevice::setDisplayBrightness ( int p) | 565 | bool ODevice::setDisplayBrightness ( int p) |
566 | { | 566 | { |
567 | Q_UNUSED( p ) | 567 | Q_UNUSED( p ) |
568 | return false; | 568 | return false; |
569 | } | 569 | } |
570 | 570 | ||
571 | /** | 571 | /** |
572 | * @return returns the number of steppings on the brightness slider | 572 | * @return returns the number of steppings on the brightness slider |
573 | * in the Light-'n-Power settings. | 573 | * in the Light-'n-Power settings. |
574 | */ | 574 | */ |
575 | int ODevice::displayBrightnessResolution ( ) const | 575 | int ODevice::displayBrightnessResolution ( ) const |
576 | { | 576 | { |
577 | return 16; | 577 | return 16; |
578 | } | 578 | } |
579 | 579 | ||
580 | /** | 580 | /** |
581 | * This sets the display contrast | 581 | * This sets the display contrast |
582 | * @param p The contrast to be set on a scale from 0 to 255 | 582 | * @param p The contrast to be set on a scale from 0 to 255 |
583 | * @return success or failure | 583 | * @return success or failure |
584 | */ | 584 | */ |
585 | bool ODevice::setDisplayContrast ( int p) | 585 | bool ODevice::setDisplayContrast ( int p) |
586 | { | 586 | { |
587 | Q_UNUSED( p ) | 587 | Q_UNUSED( p ) |
588 | return false; | 588 | return false; |
589 | } | 589 | } |
590 | 590 | ||
591 | /** | 591 | /** |
592 | * @return return the max value for the brightness settings slider | 592 | * @return return the max value for the brightness settings slider |
593 | * or 0 if the device doesn't support setting of a contrast | 593 | * or 0 if the device doesn't support setting of a contrast |
594 | */ | 594 | */ |
595 | int ODevice::displayContrastResolution ( ) const | 595 | int ODevice::displayContrastResolution ( ) const |
596 | { | 596 | { |
597 | return 0; | 597 | return 0; |
598 | } | 598 | } |
599 | 599 | ||
600 | /** | 600 | /** |
601 | * This returns the vendor as string | 601 | * This returns the vendor as string |
602 | * @return Vendor as QString | 602 | * @return Vendor as QString |
603 | */ | 603 | */ |
604 | QString ODevice::vendorString ( ) const | 604 | QString ODevice::vendorString ( ) const |
605 | { | 605 | { |
606 | return d-> m_vendorstr; | 606 | return d-> m_vendorstr; |
607 | } | 607 | } |
608 | 608 | ||
609 | /** | 609 | /** |
610 | * This returns the vendor as one of the values of OVendor | 610 | * This returns the vendor as one of the values of OVendor |
611 | * @return OVendor | 611 | * @return OVendor |
612 | */ | 612 | */ |
613 | OVendor ODevice::vendor ( ) const | 613 | OVendor ODevice::vendor ( ) const |
614 | { | 614 | { |
615 | return d-> m_vendor; | 615 | return d-> m_vendor; |
616 | } | 616 | } |
617 | 617 | ||
618 | /** | 618 | /** |
619 | * This returns the model as a string | 619 | * This returns the model as a string |
620 | * @return A string representing the model | 620 | * @return A string representing the model |
621 | */ | 621 | */ |
622 | QString ODevice::modelString ( ) const | 622 | QString ODevice::modelString ( ) const |
623 | { | 623 | { |
624 | return d-> m_modelstr; | 624 | return d-> m_modelstr; |
625 | } | 625 | } |
626 | 626 | ||
627 | /** | 627 | /** |
628 | * This does return the OModel used | 628 | * This does return the OModel used |
629 | */ | 629 | */ |
630 | OModel ODevice::model ( ) const | 630 | OModel ODevice::model ( ) const |
631 | { | 631 | { |
632 | return d-> m_model; | 632 | return d-> m_model; |
633 | } | 633 | } |
634 | 634 | ||
635 | /** | 635 | /** |
636 | * This does return the systen name | 636 | * This does return the systen name |
637 | */ | 637 | */ |
638 | QString ODevice::systemString ( ) const | 638 | QString ODevice::systemString ( ) const |
639 | { | 639 | { |
640 | return d-> m_systemstr; | 640 | return d-> m_systemstr; |
641 | } | 641 | } |
642 | 642 | ||
643 | /** | 643 | /** |
644 | * Return System as OSystem value | 644 | * Return System as OSystem value |
645 | */ | 645 | */ |
646 | OSystem ODevice::system ( ) const | 646 | OSystem ODevice::system ( ) const |
647 | { | 647 | { |
648 | return d-> m_system; | 648 | return d-> m_system; |
649 | } | 649 | } |
650 | 650 | ||
651 | /** | 651 | /** |
652 | * @return the version string of the base system | 652 | * @return the version string of the base system |
653 | */ | 653 | */ |
654 | QString ODevice::systemVersionString ( ) const | 654 | QString ODevice::systemVersionString ( ) const |
655 | { | 655 | { |
656 | return d-> m_sysverstr; | 656 | return d-> m_sysverstr; |
657 | } | 657 | } |
658 | 658 | ||
659 | /** | 659 | /** |
660 | * @return the current Transformation | 660 | * @return the current Transformation |
661 | */ | 661 | */ |
662 | Transformation ODevice::rotation ( ) const | 662 | Transformation ODevice::rotation ( ) const |
663 | { | 663 | { |
664 | return d-> m_rotation; | 664 | return d-> m_rotation; |
665 | } | 665 | } |
666 | 666 | ||
667 | /** | 667 | /** |
668 | * @return the current rotation direction | 668 | * @return the current rotation direction |
669 | */ | 669 | */ |
670 | ODirection ODevice::direction ( ) const | 670 | ODirection ODevice::direction ( ) const |
671 | { | 671 | { |
672 | return d-> m_direction; | 672 | return d-> m_direction; |
673 | } | 673 | } |
674 | 674 | ||
675 | /** | 675 | /** |
676 | * This plays an alarmSound | 676 | * This plays an alarmSound |
677 | */ | 677 | */ |
678 | void ODevice::alarmSound ( ) | 678 | void ODevice::alarmSound ( ) |
679 | { | 679 | { |
680 | #ifndef QT_NO_SOUND | 680 | #ifndef QT_NO_SOUND |
681 | static Sound snd ( "alarm" ); | 681 | static Sound snd ( "alarm" ); |
682 | 682 | ||
683 | if ( snd. isFinished ( )) | 683 | if ( snd. isFinished ( )) |
684 | snd. play ( ); | 684 | snd. play ( ); |
685 | #endif | 685 | #endif |
686 | } | 686 | } |
687 | 687 | ||
688 | /** | 688 | /** |
689 | * This plays a key sound | 689 | * This plays a key sound |
690 | */ | 690 | */ |
691 | void ODevice::keySound ( ) | 691 | void ODevice::keySound ( ) |
692 | { | 692 | { |
693 | #ifndef QT_NO_SOUND | 693 | #ifndef QT_NO_SOUND |
694 | static Sound snd ( "keysound" ); | 694 | static Sound snd ( "keysound" ); |
695 | 695 | ||
696 | if ( snd. isFinished ( )) | 696 | if ( snd. isFinished ( )) |
697 | snd. play ( ); | 697 | snd. play ( ); |
698 | #endif | 698 | #endif |
699 | } | 699 | } |
700 | 700 | ||
701 | /** | 701 | /** |
702 | * This plays a touch sound | 702 | * This plays a touch sound |
703 | */ | 703 | */ |
704 | void ODevice::touchSound ( ) | 704 | void ODevice::touchSound ( ) |
705 | { | 705 | { |
706 | #ifndef QT_NO_SOUND | 706 | #ifndef QT_NO_SOUND |
707 | static Sound snd ( "touchsound" ); | 707 | static Sound snd ( "touchsound" ); |
708 | 708 | ||
709 | if ( snd. isFinished ( )) | 709 | if ( snd. isFinished ( )) |
710 | snd. play ( ); | 710 | snd. play ( ); |
711 | #endif | 711 | #endif |
712 | } | 712 | } |
713 | 713 | ||
714 | /** | 714 | /** |
715 | * This method will return a list of leds | 715 | * This method will return a list of leds |
716 | * available on this device | 716 | * available on this device |
717 | * @return a list of LEDs. | 717 | * @return a list of LEDs. |
718 | */ | 718 | */ |
719 | QValueList <OLed> ODevice::ledList ( ) const | 719 | QValueList <OLed> ODevice::ledList ( ) const |
720 | { | 720 | { |
721 | return QValueList <OLed> ( ); | 721 | return QValueList <OLed> ( ); |
722 | } | 722 | } |
723 | 723 | ||
724 | /** | 724 | /** |
725 | * This does return the state of the LEDs | 725 | * This does return the state of the LEDs |
726 | */ | 726 | */ |
727 | QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const | 727 | QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const |
728 | { | 728 | { |
729 | return QValueList <OLedState> ( ); | 729 | return QValueList <OLedState> ( ); |
730 | } | 730 | } |
731 | 731 | ||
732 | /** | 732 | /** |
733 | * @return the state for a given OLed | 733 | * @return the state for a given OLed |
734 | */ | 734 | */ |
735 | OLedState ODevice::ledState ( OLed /*which*/ ) const | 735 | OLedState ODevice::ledState ( OLed /*which*/ ) const |
736 | { | 736 | { |
737 | return Led_Off; | 737 | return Led_Off; |
738 | } | 738 | } |
739 | 739 | ||
740 | /** | 740 | /** |
741 | * Set the state for a LED | 741 | * Set the state for a LED |
742 | * @param which Which OLed to use | 742 | * @param which Which OLed to use |
743 | * @param st The state to set | 743 | * @param st The state to set |
744 | * @return success or failure | 744 | * @return success or failure |
745 | */ | 745 | */ |
746 | bool ODevice::setLedState ( OLed which, OLedState st ) | 746 | bool ODevice::setLedState ( OLed which, OLedState st ) |
747 | { | 747 | { |
748 | Q_UNUSED( which ) | 748 | Q_UNUSED( which ) |
749 | Q_UNUSED( st ) | 749 | Q_UNUSED( st ) |
750 | return false; | 750 | return false; |
751 | } | 751 | } |
752 | 752 | ||
753 | /** | 753 | /** |
754 | * @return if the device has a light sensor | 754 | * @return if the device has a light sensor |
755 | */ | 755 | */ |
756 | bool ODevice::hasLightSensor ( ) const | 756 | bool ODevice::hasLightSensor ( ) const |
757 | { | 757 | { |
758 | return false; | 758 | return false; |
759 | } | 759 | } |
760 | 760 | ||
761 | /** | 761 | /** |
762 | * @return a value from the light senso | 762 | * @return a value from the light senso |
763 | */ | 763 | */ |
764 | int ODevice::readLightSensor ( ) | 764 | int ODevice::readLightSensor ( ) |
765 | { | 765 | { |
766 | return -1; | 766 | return -1; |
767 | } | 767 | } |
768 | 768 | ||
769 | /** | 769 | /** |
770 | * @return the light sensor resolution whatever that is ;) | 770 | * @return the light sensor resolution whatever that is ;) |
771 | */ | 771 | */ |
772 | int ODevice::lightSensorResolution ( ) const | 772 | int ODevice::lightSensorResolution ( ) const |
773 | { | 773 | { |
774 | return 0; | 774 | return 0; |
775 | } | 775 | } |
776 | 776 | ||
777 | /** | 777 | /** |
778 | * @return a list with valid CPU frequency | 778 | * @return a list with CPU frequencies supported by the hardware |
779 | */ | 779 | */ |
780 | QStrList &ODevice::cpuFrequencies ( ) const | 780 | const QStrList &ODevice::allowedCpuFrequencies ( ) const |
781 | { | 781 | { |
782 | return *d->m_cpu_frequencies; | 782 | return *d->m_cpu_frequencies; |
783 | } | 783 | } |
784 | 784 | ||
785 | 785 | ||
786 | /** | 786 | /** |
787 | * Set desired cpu frequency | 787 | * Set desired CPU frequency |
788 | * | 788 | * |
789 | * @param index index into d->m_cpu_frequencies of the frequency to be set | 789 | * @param index index into d->m_cpu_frequencies of the frequency to be set |
790 | */ | 790 | */ |
791 | bool ODevice::setCpuFrequency(uint index) | 791 | bool ODevice::setCurrentCpuFrequency(uint index) |
792 | { | 792 | { |
793 | if (index >= d->m_cpu_frequencies->count()) | 793 | if (index >= d->m_cpu_frequencies->count()) |
794 | return false; | 794 | return false; |
795 | 795 | ||
796 | char *freq = d->m_cpu_frequencies->at(index); | 796 | char *freq = d->m_cpu_frequencies->at(index); |
797 | qWarning("set freq to %s", freq); | 797 | qWarning("set freq to %s", freq); |
798 | 798 | ||
799 | int fd; | 799 | int fd; |
800 | 800 | ||
801 | if ((fd = ::open("/proc/sys/cpu/0/speed", O_WRONLY)) >= 0) { | 801 | if ((fd = ::open("/proc/sys/cpu/0/speed", O_WRONLY)) >= 0) { |
802 | char writeCommand[50]; | 802 | char writeCommand[50]; |
803 | const int count = sprintf(writeCommand, "%s\n", freq); | 803 | const int count = sprintf(writeCommand, "%s\n", freq); |
804 | int res = (::write(fd, writeCommand, count) != -1); | 804 | int res = (::write(fd, writeCommand, count) != -1); |
805 | ::close(fd); | 805 | ::close(fd); |
806 | return res; | 806 | return res; |
807 | } | 807 | } |
808 | 808 | ||
809 | return false; | 809 | return false; |
810 | } | 810 | } |
811 | 811 | ||
812 | 812 | ||
813 | /** | 813 | /** |
814 | * @return a list of hardware buttons | 814 | * @return a list of hardware buttons |
815 | */ | 815 | */ |
816 | const QValueList <ODeviceButton> &ODevice::buttons ( ) | 816 | const QValueList <ODeviceButton> &ODevice::buttons ( ) |
817 | { | 817 | { |
818 | initButtons ( ); | 818 | initButtons ( ); |
819 | 819 | ||
820 | return *d-> m_buttons; | 820 | return *d-> m_buttons; |
821 | } | 821 | } |
822 | 822 | ||
823 | /** | 823 | /** |
824 | * @return The amount of time that would count as a hold | 824 | * @return The amount of time that would count as a hold |
825 | */ | 825 | */ |
826 | uint ODevice::buttonHoldTime ( ) const | 826 | uint ODevice::buttonHoldTime ( ) const |
827 | { | 827 | { |
828 | return d-> m_holdtime; | 828 | return d-> m_holdtime; |
829 | } | 829 | } |
830 | 830 | ||
831 | /** | 831 | /** |
832 | * This method return a ODeviceButton for a key code | 832 | * This method return a ODeviceButton for a key code |
833 | * or 0 if no special hardware button is available for the device | 833 | * or 0 if no special hardware button is available for the device |
834 | * | 834 | * |
835 | * @return The devicebutton or 0l | 835 | * @return The devicebutton or 0l |
836 | * @see ODeviceButton | 836 | * @see ODeviceButton |
837 | */ | 837 | */ |
838 | const ODeviceButton *ODevice::buttonForKeycode ( ushort code ) | 838 | const ODeviceButton *ODevice::buttonForKeycode ( ushort code ) |
839 | { | 839 | { |
840 | initButtons ( ); | 840 | initButtons ( ); |
841 | 841 | ||
842 | for ( QValueListConstIterator<ODeviceButton> it = d-> m_buttons-> begin ( ); it != d-> m_buttons-> end ( ); ++it ) { | 842 | for ( QValueListConstIterator<ODeviceButton> it = d-> m_buttons-> begin ( ); it != d-> m_buttons-> end ( ); ++it ) { |
843 | if ( (*it). keycode ( ) == code ) | 843 | if ( (*it). keycode ( ) == code ) |
844 | return &(*it); | 844 | return &(*it); |
845 | } | 845 | } |
846 | return 0; | 846 | return 0; |
847 | } | 847 | } |
848 | 848 | ||
849 | void ODevice::reloadButtonMapping ( ) | 849 | void ODevice::reloadButtonMapping ( ) |
850 | { | 850 | { |
851 | initButtons ( ); | 851 | initButtons ( ); |
852 | 852 | ||
853 | Config cfg ( "ButtonSettings" ); | 853 | Config cfg ( "ButtonSettings" ); |
854 | 854 | ||
855 | for ( uint i = 0; i < d-> m_buttons-> count ( ); i++ ) { | 855 | for ( uint i = 0; i < d-> m_buttons-> count ( ); i++ ) { |
856 | ODeviceButton &b = ( *d-> m_buttons ) [i]; | 856 | ODeviceButton &b = ( *d-> m_buttons ) [i]; |
857 | QString group = "Button" + QString::number ( i ); | 857 | QString group = "Button" + QString::number ( i ); |
858 | 858 | ||
859 | QCString pch, hch; | 859 | QCString pch, hch; |
860 | QCString pm, hm; | 860 | QCString pm, hm; |
861 | QByteArray pdata, hdata; | 861 | QByteArray pdata, hdata; |
862 | 862 | ||
863 | if ( cfg. hasGroup ( group )) { | 863 | if ( cfg. hasGroup ( group )) { |
864 | cfg. setGroup ( group ); | 864 | cfg. setGroup ( group ); |
865 | pch = cfg. readEntry ( "PressedActionChannel" ). latin1 ( ); | 865 | pch = cfg. readEntry ( "PressedActionChannel" ). latin1 ( ); |
866 | pm = cfg. readEntry ( "PressedActionMessage" ). latin1 ( ); | 866 | pm = cfg. readEntry ( "PressedActionMessage" ). latin1 ( ); |
867 | // pdata = decodeBase64 ( buttonFile. readEntry ( "PressedActionArgs" )); | 867 | // pdata = decodeBase64 ( buttonFile. readEntry ( "PressedActionArgs" )); |
868 | 868 | ||
869 | hch = cfg. readEntry ( "HeldActionChannel" ). latin1 ( ); | 869 | hch = cfg. readEntry ( "HeldActionChannel" ). latin1 ( ); |
870 | hm = cfg. readEntry ( "HeldActionMessage" ). latin1 ( ); | 870 | hm = cfg. readEntry ( "HeldActionMessage" ). latin1 ( ); |
871 | // hdata = decodeBase64 ( buttonFile. readEntry ( "HeldActionArgs" )); | 871 | // hdata = decodeBase64 ( buttonFile. readEntry ( "HeldActionArgs" )); |
872 | } | 872 | } |
873 | 873 | ||
874 | b. setPressedAction ( OQCopMessage ( pch, pm, pdata )); | 874 | b. setPressedAction ( OQCopMessage ( pch, pm, pdata )); |
875 | 875 | ||
876 | b. setHeldAction ( OQCopMessage ( hch, hm, hdata )); | 876 | b. setHeldAction ( OQCopMessage ( hch, hm, hdata )); |
877 | } | 877 | } |
878 | } | 878 | } |
879 | 879 | ||
880 | void ODevice::remapPressedAction ( int button, const OQCopMessage &action ) | 880 | void ODevice::remapPressedAction ( int button, const OQCopMessage &action ) |
881 | { | 881 | { |
882 | initButtons ( ); | 882 | initButtons ( ); |
883 | 883 | ||
884 | QString mb_chan; | 884 | QString mb_chan; |
885 | 885 | ||
886 | if ( button >= (int) d-> m_buttons-> count ( )) | 886 | if ( button >= (int) d-> m_buttons-> count ( )) |
887 | return; | 887 | return; |
888 | 888 | ||
889 | ODeviceButton &b = ( *d-> m_buttons ) [button]; | 889 | ODeviceButton &b = ( *d-> m_buttons ) [button]; |
890 | b. setPressedAction ( action ); | 890 | b. setPressedAction ( action ); |
891 | 891 | ||
892 | mb_chan=b. pressedAction ( ). channel ( ); | 892 | mb_chan=b. pressedAction ( ). channel ( ); |
893 | 893 | ||
894 | Config buttonFile ( "ButtonSettings" ); | 894 | Config buttonFile ( "ButtonSettings" ); |
895 | buttonFile. setGroup ( "Button" + QString::number ( button )); | 895 | buttonFile. setGroup ( "Button" + QString::number ( button )); |
896 | buttonFile. writeEntry ( "PressedActionChannel", (const char*) mb_chan); | 896 | buttonFile. writeEntry ( "PressedActionChannel", (const char*) mb_chan); |
897 | buttonFile. writeEntry ( "PressedActionMessage", (const char*) b. pressedAction ( ). message ( )); | 897 | buttonFile. writeEntry ( "PressedActionMessage", (const char*) b. pressedAction ( ). message ( )); |
898 | 898 | ||
899 | //buttonFile. writeEntry ( "PressedActionArgs", encodeBase64 ( b. pressedAction ( ). data ( ))); | 899 | //buttonFile. writeEntry ( "PressedActionArgs", encodeBase64 ( b. pressedAction ( ). data ( ))); |
900 | 900 | ||
901 | QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); | 901 | QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); |
902 | } | 902 | } |
903 | 903 | ||
904 | void ODevice::remapHeldAction ( int button, const OQCopMessage &action ) | 904 | void ODevice::remapHeldAction ( int button, const OQCopMessage &action ) |
905 | { | 905 | { |
906 | initButtons ( ); | 906 | initButtons ( ); |
907 | 907 | ||
908 | if ( button >= (int) d-> m_buttons-> count ( )) | 908 | if ( button >= (int) d-> m_buttons-> count ( )) |
909 | return; | 909 | return; |
910 | 910 | ||
911 | ODeviceButton &b = ( *d-> m_buttons ) [button]; | 911 | ODeviceButton &b = ( *d-> m_buttons ) [button]; |
912 | b. setHeldAction ( action ); | 912 | b. setHeldAction ( action ); |
913 | 913 | ||
914 | Config buttonFile ( "ButtonSettings" ); | 914 | Config buttonFile ( "ButtonSettings" ); |
915 | buttonFile. setGroup ( "Button" + QString::number ( button )); | 915 | buttonFile. setGroup ( "Button" + QString::number ( button )); |
916 | buttonFile. writeEntry ( "HeldActionChannel", (const char *) b. heldAction ( ). channel ( )); | 916 | buttonFile. writeEntry ( "HeldActionChannel", (const char *) b. heldAction ( ). channel ( )); |
917 | buttonFile. writeEntry ( "HeldActionMessage", (const char *) b. heldAction ( ). message ( )); | 917 | buttonFile. writeEntry ( "HeldActionMessage", (const char *) b. heldAction ( ). message ( )); |
918 | 918 | ||
919 | //buttonFile. writeEntry ( "HeldActionArgs", decodeBase64 ( b. heldAction ( ). data ( ))); | 919 | //buttonFile. writeEntry ( "HeldActionArgs", decodeBase64 ( b. heldAction ( ). data ( ))); |
920 | 920 | ||
921 | QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); | 921 | QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); |
922 | } | 922 | } |
923 | 923 | ||
924 | 924 | ||
925 | 925 | ||
926 | 926 | ||
927 | /************************************************** | 927 | /************************************************** |
928 | * | 928 | * |
929 | * iPAQ | 929 | * iPAQ |
930 | * | 930 | * |
931 | **************************************************/ | 931 | **************************************************/ |
932 | 932 | ||
933 | void iPAQ::init ( ) | 933 | void iPAQ::init ( ) |
934 | { | 934 | { |
935 | d-> m_vendorstr = "HP"; | 935 | d-> m_vendorstr = "HP"; |
936 | d-> m_vendor = Vendor_HP; | 936 | d-> m_vendor = Vendor_HP; |
937 | 937 | ||
938 | QFile f ( "/proc/hal/model" ); | 938 | QFile f ( "/proc/hal/model" ); |
939 | 939 | ||
940 | if ( f. open ( IO_ReadOnly )) { | 940 | if ( f. open ( IO_ReadOnly )) { |
941 | QTextStream ts ( &f ); | 941 | QTextStream ts ( &f ); |
942 | 942 | ||
943 | d-> m_modelstr = "H" + ts. readLine ( ); | 943 | d-> m_modelstr = "H" + ts. readLine ( ); |
944 | 944 | ||
945 | if ( d-> m_modelstr == "H3100" ) | 945 | if ( d-> m_modelstr == "H3100" ) |
946 | d-> m_model = Model_iPAQ_H31xx; | 946 | d-> m_model = Model_iPAQ_H31xx; |
947 | else if ( d-> m_modelstr == "H3600" ) | 947 | else if ( d-> m_modelstr == "H3600" ) |
948 | d-> m_model = Model_iPAQ_H36xx; | 948 | d-> m_model = Model_iPAQ_H36xx; |
949 | else if ( d-> m_modelstr == "H3700" ) | 949 | else if ( d-> m_modelstr == "H3700" ) |
950 | d-> m_model = Model_iPAQ_H37xx; | 950 | d-> m_model = Model_iPAQ_H37xx; |
951 | else if ( d-> m_modelstr == "H3800" ) | 951 | else if ( d-> m_modelstr == "H3800" ) |
952 | d-> m_model = Model_iPAQ_H38xx; | 952 | d-> m_model = Model_iPAQ_H38xx; |
953 | else if ( d-> m_modelstr == "H3900" ) | 953 | else if ( d-> m_modelstr == "H3900" ) |
954 | d-> m_model = Model_iPAQ_H39xx; | 954 | d-> m_model = Model_iPAQ_H39xx; |
955 | else | 955 | else |
956 | d-> m_model = Model_Unknown; | 956 | d-> m_model = Model_Unknown; |
957 | 957 | ||
958 | f. close ( ); | 958 | f. close ( ); |
959 | } | 959 | } |
960 | 960 | ||
961 | switch ( d-> m_model ) { | 961 | switch ( d-> m_model ) { |
962 | case Model_iPAQ_H31xx: | 962 | case Model_iPAQ_H31xx: |
963 | case Model_iPAQ_H38xx: | 963 | case Model_iPAQ_H38xx: |
964 | d-> m_rotation = Rot90; | 964 | d-> m_rotation = Rot90; |
965 | break; | 965 | break; |
966 | case Model_iPAQ_H36xx: | 966 | case Model_iPAQ_H36xx: |
967 | case Model_iPAQ_H37xx: | 967 | case Model_iPAQ_H37xx: |
968 | case Model_iPAQ_H39xx: | 968 | case Model_iPAQ_H39xx: |
969 | default: | 969 | default: |
970 | d-> m_rotation = Rot270; | 970 | d-> m_rotation = Rot270; |
971 | break; | 971 | break; |
972 | } | 972 | } |
973 | 973 | ||
974 | f. setName ( "/etc/familiar-version" ); | 974 | f. setName ( "/etc/familiar-version" ); |
975 | if ( f. open ( IO_ReadOnly )) { | 975 | if ( f. open ( IO_ReadOnly )) { |
976 | d-> m_systemstr = "Familiar"; | 976 | d-> m_systemstr = "Familiar"; |
977 | d-> m_system = System_Familiar; | 977 | d-> m_system = System_Familiar; |
978 | 978 | ||
979 | QTextStream ts ( &f ); | 979 | QTextStream ts ( &f ); |
980 | d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); | 980 | d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); |
981 | 981 | ||
982 | f. close ( ); | 982 | f. close ( ); |
983 | } else { | 983 | } else { |
984 | f. setName ( "/etc/oz_version" ); | 984 | f. setName ( "/etc/oz_version" ); |
985 | 985 | ||
986 | if ( f. open ( IO_ReadOnly )) { | 986 | if ( f. open ( IO_ReadOnly )) { |
987 | d-> m_systemstr = "OpenEmbedded/iPaq"; | 987 | d-> m_systemstr = "OpenEmbedded/iPaq"; |
988 | d-> m_system = System_Familiar; | 988 | d-> m_system = System_Familiar; |
989 | 989 | ||
990 | QTextStream ts ( &f ); | 990 | QTextStream ts ( &f ); |
991 | ts.setDevice ( &f ); | 991 | ts.setDevice ( &f ); |
992 | d-> m_sysverstr = ts. readLine ( ); | 992 | d-> m_sysverstr = ts. readLine ( ); |
993 | f. close ( ); | 993 | f. close ( ); |
994 | } | 994 | } |
995 | } | 995 | } |
996 | 996 | ||
997 | 997 | ||
998 | 998 | ||
999 | 999 | ||
1000 | 1000 | ||
1001 | m_leds [0] = m_leds [1] = Led_Off; | 1001 | m_leds [0] = m_leds [1] = Led_Off; |
1002 | 1002 | ||
1003 | m_power_timer = 0; | 1003 | m_power_timer = 0; |
1004 | 1004 | ||
1005 | } | 1005 | } |
1006 | 1006 | ||
1007 | void iPAQ::initButtons ( ) | 1007 | void iPAQ::initButtons ( ) |
1008 | { | 1008 | { |
1009 | if ( d-> m_buttons ) | 1009 | if ( d-> m_buttons ) |
1010 | return; | 1010 | return; |
1011 | 1011 | ||
1012 | if ( isQWS( ) ) | 1012 | if ( isQWS( ) ) |
1013 | QWSServer::setKeyboardFilter ( this ); | 1013 | QWSServer::setKeyboardFilter ( this ); |
1014 | 1014 | ||
1015 | d-> m_buttons = new QValueList <ODeviceButton>; | 1015 | d-> m_buttons = new QValueList <ODeviceButton>; |
1016 | 1016 | ||
1017 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { | 1017 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { |
1018 | i_button *ib = ipaq_buttons + i; | 1018 | i_button *ib = ipaq_buttons + i; |
1019 | ODeviceButton b; | 1019 | ODeviceButton b; |
1020 | 1020 | ||
1021 | if (( ib-> model & d-> m_model ) == d-> m_model ) { | 1021 | if (( ib-> model & d-> m_model ) == d-> m_model ) { |
1022 | b. setKeycode ( ib-> code ); | 1022 | b. setKeycode ( ib-> code ); |
1023 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); | 1023 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); |
1024 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); | 1024 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); |
1025 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); | 1025 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); |
1026 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); | 1026 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); |
1027 | 1027 | ||
1028 | d-> m_buttons-> append ( b ); | 1028 | d-> m_buttons-> append ( b ); |
1029 | } | 1029 | } |
1030 | } | 1030 | } |
1031 | reloadButtonMapping ( ); | 1031 | reloadButtonMapping ( ); |
1032 | 1032 | ||
1033 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); | 1033 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); |
1034 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | 1034 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); |
1035 | } | 1035 | } |
1036 | 1036 | ||
1037 | 1037 | ||
1038 | //#include <linux/h3600_ts.h> // including kernel headers is evil ... | 1038 | //#include <linux/h3600_ts.h> // including kernel headers is evil ... |
1039 | 1039 | ||
1040 | typedef struct { | 1040 | typedef struct { |
1041 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ | 1041 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ |
1042 | unsigned char TotalTime; /* Units of 5 seconds */ | 1042 | unsigned char TotalTime; /* Units of 5 seconds */ |
1043 | unsigned char OnTime; /* units of 100m/s */ | 1043 | unsigned char OnTime; /* units of 100m/s */ |
1044 | unsigned char OffTime; /* units of 100m/s */ | 1044 | unsigned char OffTime; /* units of 100m/s */ |
1045 | } LED_IN; | 1045 | } LED_IN; |
1046 | 1046 | ||
1047 | typedef struct { | 1047 | typedef struct { |