summaryrefslogtreecommitdiffstats
path: root/interfaces/kimproxy
diff options
context:
space:
mode:
authorDarrell Anderson <[email protected]>2013-03-02 15:57:34 -0600
committerDarrell Anderson <[email protected]>2013-03-02 15:57:34 -0600
commit7c0b0c9dc9fcbe9c198925bdc7ee18ac6be49f4f (patch)
treec76702a7f6310fbe9d437e347535422e836e94e9 /interfaces/kimproxy
parenta2a38be7600e2a2c2b49c66902d912ca036a2c0f (diff)
parent27bbee9a5f9dcda53d8eb23863ee670ad1360e41 (diff)
downloadtdelibs-7c0b0c9dc9fcbe9c198925bdc7ee18ac6be49f4f.tar.gz
tdelibs-7c0b0c9dc9fcbe9c198925bdc7ee18ac6be49f4f.zip
Merge branch 'master' of http://scm.trinitydesktop.org/scm/git/tdelibs
Diffstat (limited to 'interfaces/kimproxy')
-rw-r--r--interfaces/kimproxy/CMakeLists.txt13
-rw-r--r--interfaces/kimproxy/Makefile.am1
-rw-r--r--interfaces/kimproxy/TODO10
-rw-r--r--interfaces/kimproxy/interface/CMakeLists.txt22
-rw-r--r--interfaces/kimproxy/interface/Makefile.am13
-rw-r--r--interfaces/kimproxy/interface/dcopinstantmessenger.desktop72
-rw-r--r--interfaces/kimproxy/interface/kcm_instantmessenger.desktop138
-rw-r--r--interfaces/kimproxy/interface/kimiface.h500
-rw-r--r--interfaces/kimproxy/library/CMakeLists.txt51
-rw-r--r--interfaces/kimproxy/library/Makefile.am26
-rw-r--r--interfaces/kimproxy/library/icons/CMakeLists.txt13
-rw-r--r--interfaces/kimproxy/library/icons/Makefile.am1
-rw-r--r--interfaces/kimproxy/library/icons/cr16-action-presence_away.pngbin852 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr16-action-presence_offline.pngbin549 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr16-action-presence_online.pngbin922 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr16-action-presence_unknown.pngbin822 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr32-action-presence_away.pngbin2402 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr32-action-presence_offline.pngbin1407 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr32-action-presence_online.pngbin2547 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr32-action-presence_unknown.pngbin2483 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr48-action-presence_away.pngbin3328 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr48-action-presence_offline.pngbin1717 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/icons/cr48-action-presence_online.pngbin3370 -> 0 bytes
-rw-r--r--interfaces/kimproxy/library/kimproxy.cpp653
-rw-r--r--interfaces/kimproxy/library/kimproxy.h654
-rw-r--r--interfaces/kimproxy/library/kimproxyiface.h38
26 files changed, 0 insertions, 2205 deletions
diff --git a/interfaces/kimproxy/CMakeLists.txt b/interfaces/kimproxy/CMakeLists.txt
deleted file mode 100644
index f52118353..000000000
--- a/interfaces/kimproxy/CMakeLists.txt
+++ /dev/null
@@ -1,13 +0,0 @@
-#################################################
-#
-# (C) 2010 Serghei Amelian
-# serghei (DOT) amelian (AT) gmail.com
-#
-# Improvements and feedback are welcome
-#
-# This file is released under GPL >= 2
-#
-#################################################
-
-add_subdirectory( interface )
-add_subdirectory( library )
diff --git a/interfaces/kimproxy/Makefile.am b/interfaces/kimproxy/Makefile.am
deleted file mode 100644
index 105f84291..000000000
--- a/interfaces/kimproxy/Makefile.am
+++ /dev/null
@@ -1 +0,0 @@
-SUBDIRS = interface library \ No newline at end of file
diff --git a/interfaces/kimproxy/TODO b/interfaces/kimproxy/TODO
deleted file mode 100644
index fc66130fe..000000000
--- a/interfaces/kimproxy/TODO
+++ /dev/null
@@ -1,10 +0,0 @@
-For the future, the following modifications need to be done:
-
-Currently there is a function :
- virtual QString presenceString( const QString & uid ) = 0;
-This needs to be broken into:
- virtual QString presenceString( const QString & uid ) = 0;
- virtual QString presenceLongString( const QString & uid ) = 0;
-
-The former returning, say "Away", the latter returning the long away
-message.
diff --git a/interfaces/kimproxy/interface/CMakeLists.txt b/interfaces/kimproxy/interface/CMakeLists.txt
deleted file mode 100644
index d62819ed8..000000000
--- a/interfaces/kimproxy/interface/CMakeLists.txt
+++ /dev/null
@@ -1,22 +0,0 @@
-#################################################
-#
-# (C) 2010 Serghei Amelian
-# serghei (DOT) amelian (AT) gmail.com
-#
-# Improvements and feedback are welcome
-#
-# This file is released under GPL >= 2
-#
-#################################################
-
-##### headers ###################################
-
-install( FILES
- kimiface.h
- DESTINATION ${INCLUDE_INSTALL_DIR} )
-
-
-##### other data ################################
-
-install( FILES kcm_instantmessenger.desktop DESTINATION ${DATA_INSTALL_DIR}/kcm_componentchooser )
-install( FILES dcopinstantmessenger.desktop DESTINATION ${SERVICETYPES_INSTALL_DIR} )
diff --git a/interfaces/kimproxy/interface/Makefile.am b/interfaces/kimproxy/interface/Makefile.am
deleted file mode 100644
index 348130e46..000000000
--- a/interfaces/kimproxy/interface/Makefile.am
+++ /dev/null
@@ -1,13 +0,0 @@
-INCLUDES = $(all_includes)
-
-kimifaceinclude_HEADERS = kimiface.h
-kimifaceincludedir = $(includedir)
-
-servicetypedir = $(kde_servicetypesdir)
-servicetype_DATA = dcopinstantmessenger.desktop
-
-kcm_instantmessenger_DATA = kcm_instantmessenger.desktop
-kcm_instantmessengerdir = $(kde_datadir)/kcm_componentchooser
-
-include $(top_srcdir)/admin/Doxyfile.am
-DOXYGEN_REFERENCES = kabc
diff --git a/interfaces/kimproxy/interface/dcopinstantmessenger.desktop b/interfaces/kimproxy/interface/dcopinstantmessenger.desktop
deleted file mode 100644
index a69994421..000000000
--- a/interfaces/kimproxy/interface/dcopinstantmessenger.desktop
+++ /dev/null
@@ -1,72 +0,0 @@
-[Desktop Entry]
-Type=ServiceType
-X-TDE-ServiceType=DCOP/InstantMessenger
-Comment=Instant Messenger with a DCOP interface
-Comment[af]=Oombliklike Boodskapper met DCOP intervlak
-Comment[be]=Імгненны абвестнік з інтэрфэйсам DCOP
-Comment[bg]=Програма за съобщения в реално време с интерфейс DCOP
-Comment[bn]=ডিকপ (DCOP) ইন্টারফেস সহ ইনস্ট্যান্ট মেসেঞ্জার
-Comment[bs]=Instant poruke sa DCOP interfejsom
-Comment[ca]=Missatgeria instantània amb una interfície DCOP
-Comment[cs]=Komunikátor s DCOP rozhraním
-Comment[csb]=Internetowi kòmùnikator z interfejsã DCOP
-Comment[cy]=Negesydd Chwim efo rhyngwyneb DCOP
-Comment[da]=Instant Messenger med en DCOP-grænseflade
-Comment[de]=Instant Messenger mit DCOP-Schnittstelle
-Comment[el]=Στιγμιαίος αποστολέας με διασύνδεση DCOP
-Comment[eo]=Tujmesaĝilo kun DCOP-interfaco
-Comment[es]=Instant Messenger con un interfaz DCOP
-Comment[et]=Kiirsuhtlemisrakendus DCOP-liidesega
-Comment[eu]=Berehalako mezularitza DCOP interfazearekin
-Comment[fa]=پیام‌رسان فوری با یک واسط DCOP
-Comment[fi]=Pikaviestiohjelma, jossa on DCOP-rajapinta
-Comment[fr]=Messagerie instantanée munie d'une interface DCOP
-Comment[fy]=Instant Messenger mei in DCOP-interface
-Comment[ga]=Clár teachtaireachtaí meandaracha le comhéadan DCOP
-Comment[gl]=Mensaxeria Instantánea con interface DCOP
-Comment[he]=תכנת מסרים מידיים עם ממשק DCOP
-Comment[hi]=डीकॉप इंटरफेस सहित इंस्टैंट मैसेंजर
-Comment[hr]=Trenutne poruke s DCOP sučeljem
-Comment[hsb]=Instant Messenger z DCOP-interfejsom
-Comment[hu]=Azonnali üzenetküldő DCOP-felülettel
-Comment[id]=Instant Messenger dengan antarmuka DCOP
-Comment[is]=Spjallforrit með DCOP viðmóti
-Comment[it]=Messaggistica istantanea con un'interfaccia DCOP
-Comment[ja]=DCOP インターフェースをもつインスタントメッセンジャー
-Comment[ka]=DCOP ინტერფეისთან შეტყობინებების გაცვლის შიკრიკი
-Comment[kk]=DCOP интерфейсті жедел хабарласу бағдарламасы
-Comment[km]=​កម្មវិធី​ជជែក​កំសាន្ត​ដែល​មាន​ចំណុច​ប្រទាក់ DCOP
-Comment[lb]=Instant Messenger mat engem DCOP-Interface
-Comment[lt]=Momentinių žinučių klientas su DCOP sąsaja
-Comment[mk]=Инстант Гласник (Messenger) со DCOP интерфејс
-Comment[ms]=Utusan Segera dengan antaramuka DCOP
-Comment[nb]=Lynmeldingsprogram med DCOP-grensesnitt
-Comment[nds]=Kortnarichten-Maker mit DCOP-Koppelsteed
-Comment[ne]=DCOP इन्टरफेससँग आवश्यक मेसेन्जर
-Comment[nl]=Instant messenger met een DCOP interface
-Comment[nn]=Lynmeldingsprogram med DCOP-grensesnitt
-Comment[pa]=ਇੱਕ DCOP ਇੰਟਰਫੇਸ ਲਈ ਇੱਕ ਮੌਕਾ ਸੁਨੇਹਾਕਾਰ
-Comment[pl]=Komunikator internetowy z interfejsem DCOP
-Comment[pt]=Mensageiro Instantâneo com interface DCOP
-Comment[pt_BR]=Mensageiro Instantâneo com uma interface DCOP
-Comment[ro]=Aplicaţie de mesaje instantanee cu interfaţă DCOP
-Comment[ru]=Клиент обмена сообщениями с интерфейсом DCOP
-Comment[rw]=Intumwa y'Akokanya ifite imigaragarire DCOP
-Comment[se]=Šleađgadiehtoprográmma mas lea DCOP-lákta
-Comment[sk]=Instant Messanger s rozhraním DCOP
-Comment[sl]=Takojšni sporočilnik z vmesnikom DCOP
-Comment[sr]=Брзи гласник са DCOP интерфејсом
-Comment[sr@Latn]=Brzi glasnik sa DCOP interfejsom
-Comment[sv]=Direktmeddelanden med ett DCOP-gränssnitt
-Comment[ta]=உடனடி செய்தியாளர் DCOP இடைமுகத்தோடு
-Comment[te]=డిసిఓపి ఇంటర్ఫెస్ కలిగివున్న ఇంస్టెంట్ మెస్సెన్జర్
-Comment[tg]=Мубодилаи паёмҳо бо интерфейси DCOP
-Comment[th]=โปรแกรมส่งข้อความแบบทันที ด้วยส่วนติดต่อกับ DCOP
-Comment[tr]=DCOP arayüzüyle Anında Mesajlaşma
-Comment[tt]=DCOP protokolı belän Aşığıç Xäbärçe
-Comment[uk]=Програма для миттєвого зв'язку через DCOP
-Comment[vi]=Bộ tin nhắn tức khắc có giao diện DCOP
-Comment[wa]=Messaedjreye sol moumint avou ene eterface DCOP
-Comment[zh_CN]=带 DCOP 接口的即时通讯程序
-Comment[zh_HK]=附有 DCOP 介面的即時通訊軟件
-Comment[zh_TW]=DCOP 介面的即時通訊系統
diff --git a/interfaces/kimproxy/interface/kcm_instantmessenger.desktop b/interfaces/kimproxy/interface/kcm_instantmessenger.desktop
deleted file mode 100644
index 860f82944..000000000
--- a/interfaces/kimproxy/interface/kcm_instantmessenger.desktop
+++ /dev/null
@@ -1,138 +0,0 @@
-Name=Instant Messenger
-Name[af]=Oombliklike Boodskapper
-Name[be]=Імгненны абвеснік
-Name[bg]=Съобщения в реално време
-Name[bn]=ইনস্ট্যান্ট মেসেঞ্জার
-Name[br]=Posteler a-benn-kaer
-Name[bs]=Instant poruke
-Name[ca]=Missatgeria instantània
-Name[cs]=Komunikátor
-Name[csb]=Internetowi kòmùnikator
-Name[cy]=Negesydd Chwim
-Name[el]=Στιγμιαίος αποστολέας
-Name[eo]=Tujmesaĝilo
-Name[et]=Kiirsuhtlus
-Name[eu]=Berehalako mezularitza
-Name[fa]=پیام‌رسان فوری
-Name[fi]=Pikaviestiohjelma
-Name[fr]=Messagerie instantanée
-Name[ga]=Clár teachtaireachtaí meandaracha
-Name[gl]=Mensaxeria Instantánea
-Name[he]=מסרים מידיים
-Name[hi]=इंस्टैंट मैसेंजर
-Name[hu]=Azonnali üzenetküldő
-Name[is]=Spjallforrit
-Name[it]=Messaggistica istantanea
-Name[ja]=インスタントメッセンジャー
-Name[ka]=შიკრიკი
-Name[kk]=Жедел хабарласу
-Name[km]=កម្មវិធី​វិធីជជែក​កំសាន្ត
-Name[lt]=Momentinių žinučių klientas
-Name[mk]=Инстант Гласник (Messenger)
-Name[ms]=Mesej Segera
-Name[nb]=Lynmelding
-Name[nds]=Kortnarichten-Maker
-Name[ne]=आवश्यक मेसेन्जर
-Name[nl]=Instant messenger
-Name[nn]=Lynmelding
-Name[pa]=ਮੌਕਾ ਸੁਨੇਹਾਕਾਰ
-Name[pl]=Komunikator internetowy
-Name[pt]=Mensageiro Instantâneo
-Name[pt_BR]=Mensagem Instantâneo
-Name[ro]=Mesaje instantanee
-Name[ru]=Обмен сообщениями
-Name[se]=Šleađgadieđut
-Name[sl]=Takojšni sporočilnik
-Name[sr]=Брзи гласник
-Name[sr@Latn]=Brzi glasnik
-Name[sv]=Direktmeddelanden
-Name[ta]=உடனடி செய்தியாளர்
-Name[te]=ఇంస్టెంట్ మెస్సెన్జర్
-Name[tg]=Мубодилаи паёмҳо
-Name[th]=โปรแกรมส่งข้อความทันที
-Name[tr]=Anında Mesajlaşma
-Name[tt]=Aşığıç Xäbärçe
-Name[uk]=Програма для миттєвого зв'язку через DCOP
-Name[uz]=Xabar almashish vositasi
-Name[uz@cyrillic]=Хабар алмашиш воситаси
-Name[vi]=Bộ tin nhắn tức khắc
-Name[wa]=Messaedjreye sol moumint
-Name[zh_CN]=即时通讯程序
-Name[zh_HK]=即時通訊軟件
-Name[zh_TW]=即時通訊
-Comment=The instant messenger allows two-way chat between individuals and groups.
-Comment[af]=Die oombliklike boodskappe laat twee rigting kommunikasie tussen individue en groepe toe.
-Comment[be]=Імгненны абвеснік дазваляе весці размову двум і больш асобам/гуртам.
-Comment[bg]=Разговор между различни хора в реално време.
-Comment[bn]=ইনস্ট্যান্ট মেসেঞ্জার একাধিক ব্যক্তি বা গোষ্ঠীকে দ্বিমুখী বার্তালাপ বা আড্ডার সুযোগ দেয়।
-Comment[bs]=Program za instant poruke omogućuje dvosmjernu komunikaciju između pojedinaca i grupa.
-Comment[ca]=La missatgeria instantània permet converses en dos sentits entre individus i grups.
-Comment[cs]=Komunikátor vám umožňuje obousměrný rozhovor s jednotlivci nebo skupinami.
-Comment[csb]=Internetowi kòmùnikator dôwô mòżnota kôrbionczi midzë lëdzama ë karnama.
-Comment[cy]=Mae'r negesydd chwim yn caniatàu sgwrs dwy-ffordd rhwng unigolion a grwpiau.
-Comment[da]=Instant messenger tillader tovejs chat mellem individer og grupper.
-Comment[de]=Der Instant Messenger ermöglicht Chats zwischen Personen und Gruppen in jede Richtung.
-Comment[el]=Ο στιγμιαίος αποστολέας επιτρέπει τη συζήτηση μεταξύ ατόμων και ομάδων.
-Comment[eo]=La tujmesaĝilo ebligas ambaŭdirekta parolado inter homoj kaj grupoj
-Comment[es]=El Instant Messenger permite conversación en dos sentidos entre indivíduos y grupos.
-Comment[et]=Kiirsuhtlus võimaldab üksikisikute ja gruppide kahepoolset vestlust.
-Comment[eu]=Berehalako mezularitzak banan-banako edo taldeen arteko berriketan aritzeko.
-Comment[fa]=پیام‌رسان فوری امکان گپ دو طرفه بین افراد و گروهها را می‌دهد.
-Comment[fi]=Pikaviestiohjelman avulla voidaan keskustella kahden kesken tai ryhmässä.
-Comment[fr]=La messagerie instantanée permet un dialogue bidirectionnel entre individus et groupes.
-Comment[fy]=Mei de instant messenger kinne jo twaspraak hâlde mei in yndividu en groepen.
-Comment[ga]=Is féidir comhrá déthreoch a dhéanamh idir daoine agus grúpaí leis an gclár teachtaireachtaí meandaracha.
-Comment[gl]=O instant messenger permite conversas nos dous sentidos entre indivíduos e grupos.
-Comment[he]=תוכנת מסרים מידיים מאשרת לשוחח ברשת (לצ'טט) בין יחידים או קבוצות
-Comment[hi]=इंस्टैंट मैसेंजर जो व्यक्तियों या समूहों के बीच दो-तरफा गपशप स्वीकारता है.
-Comment[hr]=Trenutne poruke omogućuju dvosmjerno brbljanje između pojedinaca i grupa.
-Comment[hsb]=Instant messenger zmóžni jednotliwcam a skupinam spěšnu wuměnu zdźělenkow.
-Comment[hu]=Interaktív társalgást tesz lehetővé az interneten keresztül két személy vagy csoport között.
-Comment[id]=Instant messenger memungkinan chat dua-arah antara individu dan grup
-Comment[is]=Spjallforritið gerir einstaklingum og hópum kleyft að spjalla saman á einfaldan máta.
-Comment[it]=La messaggistica istantanea permette di chiacchierare tra due persone o in gruppo.
-Comment[ja]=インスタントメッセンジャーは個人とグループとの双方向チャットを可能にします。
-Comment[ka]=შიკრიკი პიროვნებებსა და ჯგუფებს შორის მყისი შეტყობინებების გაცვლის საშუალებას იძლევა.
-Comment[kk]=Жедел хабарласу жеке тұлға және топтар араларында әңгімелесу мүмкіндігін береді.
-Comment[km]=កម្មវិធី​ជជែក​កំសាន្ត​អនុញ្ញាត​ឲ្យ​ជជែក​តាម​របៀប​ពីរ​បែប​រវាង​បុគ្គល និង​ក្រុម ។
-Comment[lb]=Den Instant Messenger erlaabt eng zwee-Weeër Kommunikatioun tëschent eenzelne Persounen a Gruppen.
-Comment[lt]=Momentinių žinučių klientas kalbėtis individams ir grupėms.
-Comment[mk]=Инстант гласникот овозможува двонасочна комуникација меѓу индивидуи и групи.
-Comment[ms]=Utusan segera membenarkan perbualan di antara individu dan kumpulan.
-Comment[nb]=Et lynmeldingsprogram som tallater toveis samtale mellom enkeltpersoner og grupper.
-Comment[nds]=Mit den Kortnarichten-Maker köönt enkelte Minschen oder Gruppen ünnerenanner snacken.
-Comment[ne]= आवश्यक मेसेन्जरले एकल र समूहहरुबीच दोहोरो कुराकानीलाई अनुमति दिन्छ ।
-Comment[nl]=De instant messenger maakt directe communicatie tussen personen of groepen mogelijk.
-Comment[nn]=Eit lynmeldingsprogram som tillèt tovegsprat mellom enkeltpersonar og grupper.
-Comment[pa]=ਇਹ ਮੌਕਾ ਸੁਨੇਹਾਕਾਰ ਇੱਕਲੇ ਤੇ ਸਮੂਹ ਵਿਚਕਾਰ ਦੋ ਪਾਸੀ ਗਲਬਾਤ ਲਈ ਸਹਾਇਕ ਹੈ
-Comment[pl]=Komunikator internetowy umożliwia pogawędki między dwiema osobami lub grupami osób.
-Comment[pt]=O mensageiro instantâneo permite conversar entre dois extremos com indivíduos e com grupos.
-Comment[pt_BR]=O mensageiro instantâneo permite que exista um bate-papo entre indivíduos e grupos
-Comment[ro]=Aplicaţia de mesaje instantanee permite convorbiri între persoane sau grupuri de persoane.
-Comment[ru]=Клиент обмена сообщениями служит для обмена сообщениями между людьми и группами.
-Comment[rw]=Intumwa y'Akokanya yemerera inzira-zombi z'ikiganiroInterineti hagati y'abantu ubwabo n'amatsinda
-Comment[se]=Šleađgadiehtoprográmma gos olbmot ja joavkkut sáhttet buillardallat (chat).
-Comment[sk]=Instant messenger umožňuje rozhovor medzi rôznymi osobami a skupinami.
-Comment[sl]=Takojšni sporočilnik omogoča dvosmeren klepet med posamezniki in skupinami.
-Comment[sr]=Брзи гласник вам омогућава двосмерно ћаскање између појединаца и група.
-Comment[sr@Latn]=Brzi glasnik vam omogućava dvosmerno ćaskanje između pojedinaca i grupa.
-Comment[sv]=Direktmeddelanden möjliggör tvåvägschatt mellan individer och grupper.
-Comment[ta]=உடனடி தகவல் உங்களை இரண்டு வழியில் தனிநபர் மற்றும் குழுக்கள் இடையே அனுமதிக்கும்.
-Comment[te]=ఇంస్టెంట్ మెస్సెన్జర్ వ్యక్తు లు మరయు గుంపుల తొ ఇరువయపుల నుంచి సంబాషించవచ్చు
-Comment[tg]=Мубодилаи паёмҳо барои сӯҳбат бо шахсони ҷудогона ва гурӯҳӣ иҷозат медиҳад.
-Comment[th]=โปรแกรมส่งข้อความแบบทันที จะอนุญาตให้มีการพูดคุยสองทาง ทั้งระหว่าง บุคคลและกลุ่ม
-Comment[tr]=Anında mesajlaştırıcı iki yollu sohbet sağlar: bireyler ve gruplar.
-Comment[tt]=Bu aşığıç xäbärçe aşa keşe-törkemnär arasında ike-yaqlı aralaşu mömkinlegen birä.
-Comment[uk]=Програма для миттєвого зв'язку дозволяє розмовляти з іншою людиною чи групою людей.
-Comment[vi]=Bộ tin nhắn tức khắc cho phép trò chuyện hai chiều giữa người riêng và nhóm.
-Comment[wa]=Li messaedjreye sol moumint permete di berdeler dins les deus sinses etur deus djins ou e groupe.
-Comment[zh_CN]=允许在个人和群组之间双向聊天的即时通讯程序。
-Comment[zh_HK]=即時通訊軟件可以讓用戶和別的用戶或羣組通訊。
-Comment[zh_TW]=即時通訊系統允許兩個人或兩個群組間的聊天與對話
-ServiceTypeToConfigure=DCOP/InstantMessenger
-MimeTypeOfInterest=DCOP/InstantMessenger
-defaultImplementation=kopete
-storeInFile=default_components
-valueSection=InstantMessenger
-valueName=imClient
-configurationType=component
diff --git a/interfaces/kimproxy/interface/kimiface.h b/interfaces/kimproxy/interface/kimiface.h
deleted file mode 100644
index f3212df6d..000000000
--- a/interfaces/kimproxy/interface/kimiface.h
+++ /dev/null
@@ -1,500 +0,0 @@
-/*
- kimiface.h - KDE Instant Messenger DCOP Interface
-
- Copyright (c) 2004-5 Will Stephenson <[email protected]>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library 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
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#ifndef KIMIFACE_H
-#define KIMIFACE_H
-
-#include <tqpixmap.h>
-#include <dcopobject.h>
-#include <tqstringlist.h>
-#include <kurl.h>
-
-/**
- * @brief Generic DCOP interface for KDE instant messenger applications
- *
- * The interface has two parts:
- * - methods to get information about IM-contacts, such as their reachability
- * or their presence status (if the are online or away, etc)
- * - methods to initiate communication with IM-contacts, e.g. sending messages
- *
- * @note If you are looking for a information about accessing application's
- * that implement this interface, have a look at the KIMProxy class.
- *
- * Contacts are identified using unique identifier strings (UID) used by
- * KABC, the KDE address book library.
- * The UID generation is handled by KABC::Addressee so the your application
- * will either have to access the address book or provide a possibility
- * for associating a contact of your application with an entry of the address
- * book.
- *
- * @note one omission of this interface is the lack of control over the range
- * of values used for protocols' names.
- *
- * If you are implementing this interface, note that your application must
- * have the following information in its desktop file, so that it can be
- * identified as providing KIMIface at runtime:
- * @code
- * X-DCOP-ServiceName=<application-name>
- * ServiceTypes=DCOP/InstantMessenger
- * @endcode
- * and the class implementing KIMIface must pass "KIMIface" to the DCOPObject constructor:
- * @code
- * // just need TQObject inheritance and Q_OBJECT if you want signals and slots
- * // no need to use K_DCOP macro again
- *
- * class MyIMIface : public TQObject, public KIMIface
- * {
- * Q_OBJECT
- * public:
- * MyIMIface(TQObject* parent = 0, const char* name) :
- * DCOPObject("KIMIface"), // <-- passing the interface name as required
- * TQObject(parent, name) {}
- * };
- * @endcode
- *
- * The DCOP part of the interface needs to be processed by the DCOP IDL
- * compiler. The KDE autotools framework will do this automatically, all
- * you have to do is add kimiface.skel and kimiface.stub to the
- * @c SOURCES list in your @c Makefile.am
- *
- * @see KIMProxy
- * @see KABC::AddressBook
- * @see KABC::Addressee
- *
- * @since 3.3
- * @author Will Stephenson <[email protected]>
- */
-class KIMIface : virtual public DCOPObject
-{
- K_DCOP
-
-k_dcop:
-// ACCESSORS
-// contact list
- /**
- * @brief Obtain a list of IM-contacts that are known to the application
- *
- * Return a list of KABC UIDs of all the contacts you have such IDs for.
- *
- * @return a list of KABC UIDs known to the application
- *
- * @see reachableContacts()
- * @see onlineContacts()
- * @see fileTransferContacts()
- * @see isPresent()
- * @see KABC::Addressee::uid()
- */
- virtual TQStringList allContacts() = 0;
-
- /**
- * @brief Obtain a list of IM-contacts that are currently reachable
- *
- * Return a list of KABC UIDs of the contacts that are reachable in the
- * sense that you are connected to the IM-service they are
- * associated with.
- *
- * For example if your application supports ICQ and AIM and the ICQ account is
- * active but the AIM account isn't, return just the ICQ contacts.
- *
- * @return a list of KABC UIDs who can receive a message, even if offline
- *
- * @see allContacts()
- * @see onlineContacts()
- * @see fileTransferContacts()
- * @see messageContact()
- * @see KABC::Addressee::uid()
- */
- virtual TQStringList reachableContacts() = 0;
-
- /**
- * @brief Obtain a list of IM-contacts that are currently online
- *
- * Return a list of KABC UIDs of the contacts you have any presence
- * information for that indicates that they are connected to the
- * IM-service they are associated with.
- *
- * @return a list of KABC UIDs who are online with unspecified presence
- *
- * @see allContacts()
- * @see reachableContacts()
- * @see fileTransferContacts()
- * @see messageContact()
- * @see chatWithContact()
- * @see KABC::Addressee::uid()
- */
- virtual TQStringList onlineContacts() = 0;
-
- /**
- * @brief Obtain a list of IM-contacts who may receive file transfers
- *
- * Return a list of KABC UIDs of the contacts that are capable of
- * receiving file transfers based on the IM-service they are associated
- * with, i.e. if it is technically able to provide this, on their online
- * state, i.e. can likely not receive files while offline, and perhaps even
- * information your application has additionally, e.g. a user config that
- * tells you that the contact is behind a firewall.
- *
- * The simplest implementation is to return the same list as
- * onlineContacts(), provided all the IM-services that are currently used
- * support it.
- *
- * @return a list of KABC UIDs capable of file transfer
- *
- * @see allContacts()
- * @see reachableContacts()
- * @see onlineContacts()
- * @see canReceiveFiles()
- * @see sendFile()
- * @see KABC::Addressee::uid()
- */
- virtual TQStringList fileTransferContacts() = 0;
-
-// individual
- /**
- * @brief Confirm if a given contact is known to the IM application
- *
- * Check if you can map the given KABC UID to one if the IM-contacts, e.g.
- * the would be part of the list returned by allContacts()
- *
- * @param uid the KABC UID you are interested in
- * @return whether the program knows of this KABC UID
- *
- * @see allContacts()
- * @see presenceString()
- * @see presenceStatus()
- * @see KABC::Addressee::uid()
- */
- virtual bool isPresent( const TQString & uid ) = 0;
-
- /**
- * @brief Obtain the IM app's idea of the contact's display name
- *
- * Useful if KABC lookups may be too slow. Should return whatever
- * the application uses in its contact list or similar GUI, e.g.
- * a nick name, a user configured name string, etc.
- *
- * @param uid the KABC UID you are interested in
- * @return the corresponding display name or TQString:null if the
- * UID is unknown
- *
- * @see isPresent()
- * @see presenceString()
- * @see presenceStatus()
- * @see KABC::Addressee::uid()
- */
- virtual TQString displayName( const TQString & uid ) = 0;
-
- /**
- * @brief Obtain the IM presence as a i18ned string for the specified
- * contact
- *
- * Return a translated string your application would use when displaying
- * the contact's presence, e.g. i18n("Online"), i18n("Away")
- *
- * @param uid the KABC UID you want the presence for
- * @return the i18ned string describing the contact's presence or
- * TQString::null if the UID is unknown
- *
- * @see isPresent()
- * @see presenceStatus()
- * @see KABC::Addressee::uid()
- */
- virtual TQString presenceString( const TQString & uid ) = 0;
-
- /**
- * @brief Obtain the IM presence as a number for the specified contact
- *
- * Return one of the following values depending on the given contact's
- * presence:
- * - 0 - @c Unknown: for contacts where you can not use any of the other
- * values
- *
- * - 1 - @c Offline: for contacts that are offline, i.e. not connected to
- * their IM-service. If the application itself or the IM-service for the
- * given contact is offline return @c Unknown instead
- *
- * - 2 - @c Connecting
- *
- * - 3 - @c Away: for contacts that are connected to their IM-service but
- * not @c Online
- *
- * - 4 - @c Online
- *
- * @param uid the KABC UID you want the presence for
- * @return a numeric representation of presence - currently one of
- * 0 (Unknown), 1 (Offline), 2 (Connecting), 3 (Away), 4 (Online).
- * Returns 0 if the given UID is unknown
- *
- * @see isPresent()
- * @see presenceString()
- * @see KABC::Addressee::uid()
- */
- virtual int presenceStatus( const TQString & uid ) = 0;
-
- /**
- * @brief Indicate if a given contact can receive files
- *
- * @param uid the KABC UID you want to the file transfer capability for
- * @return whether the specified contact can receive files
- *
- * @see fileTransferContacts()
- * @see KABC::Addressee::uid()
- */
- virtual bool canReceiveFiles( const TQString & uid ) = 0;
-
- /**
- * @brief Indicate if a given contact will be able to respond
- *
- * Some media are unidirectional (e.g., sending SMS via a web interface).
- * This refers to the contact's ability to respond as defined by the
- * medium, not by their presence.
- *
- * Someone may appear offline (SMS has no presence) to you but in fact be
- * able to respond.
- *
- * @param uid the KABC UID you are interested in
- * @return whether the specified contact can respond
- *
- * @see isPresent()
- * @see KABC::Addressee::uid()
- */
- virtual bool canRespond( const TQString & uid ) = 0;
-
- /**
- * @brief Obtain the KABC UID corresponding to the given IM address
- *
- * @param contactId the protocol specific identifier for the contact,
- * e.g. UIN for ICQ, screenname for AIM, nick for IRC
- * @param protocol the IM protocol/service to check. See protocols()
- * @return the KABC UID for the given contact or @c TQString::null if not
- * found or either input stream was empty or the protocol is not
- * supported
- *
- * @see protocols()
- * @see addContact()
- * @see isPresent()
- * @see KABC::Addressee::uid()
- */
- virtual TQString locate( const TQString & contactId, const TQString & protocol ) = 0;
-
-// metadata
- /**
- * @brief Obtain the icon representing the IM presence for the specified
- * contact
- *
- * Return the image the application would use to display a contact's presence.
- * The size and other properties of the image are currently unspecified.
- *
- * @param uid the KABC UID you want the presence icon for
- * @return a pixmap representing the contact's presence or a null pixmap
- * if the contact is unknown. See TQPixmap::isNull()
- *
- * @see isPresent()
- * @see presenceString()
- * @see presenceStatus()
- * @see KABC::Addressee::uid()
- */
- virtual TQPixmap icon( const TQString & uid ) = 0;
-
- /**
- * @brief Obtain the given contact's current context (home, work, or any)
- *
- * Not all IM services/protocols support the concept of contexts. If the
- * given UID maps to such a service, just return @c TQString::null
- *
- * @param uid the KABC UID you want the context for
- * @return a string describing the context, or @c TQString::null if not
- * supported or if the contact is unknown
- *
- * @see isPresent()
- * @see KABC::Addressee::uid()
- */
- virtual TQString context( const TQString & uid ) = 0;
-
-// App capabilities
- /**
- * @brief Obtain a list of supported IM services/protocols
- *
- * Protocol names are currently of the form "protocol name" + "Protocol"
- * for example:
- * - AIMProtocol: AOL instant messenger protocol
- * - MSNProtocol: Microsoft messanger protocol
- * - ICQProtocol: AOL (Mirabilis) ICQ protocol
- * - ....
- *
- * The string is currently just an identifier to use with methods such as
- * locate(), addContact() or messageNewContact()
- *
- * @return the set of protocols that the application supports
- *
- * @see locate()
- * @see addContact()
- * @see messageNewContact
- */
- virtual TQStringList protocols() = 0;
-
-// ACTORS
- /**
- * @brief Send a single message to the specified contact
- *
- * Any response will be handled by the IM client as a normal
- * conversation.
- *
- * Implementations might send the message silently, ask the user for
- * permission or just prefill the usual message input GUI.
- *
- * @note As sending any text could potentially be a breach of the user's
- * privacy it is recommended to let the user know about it.
- *
- * @param uid the KABC UID you want to send the message to
- * @param message the message text to send to the contact
- *
- * @see messageNewContact()
- * @see chatWithContact()
- * @see sendFile()
- * @see isPresent()
- * @see reachableContacts()
- * @see KABC::Addressee::uid()
- */
- virtual void messageContact( const TQString &uid, const TQString& message ) = 0;
-
- /**
- * @brief Send a single message to a contact given only its protocol
- * specific identifier
- *
- * This could be used to send a message without having to know the KABC UID
- * of the contact or without having to add it first.
- *
- * @param contactId the protocol specific identifier for the contact,
- * e.g. UIN for ICQ, screenname for AIM, nick for IRC
- * @param protocol the IM protocol/service to check. See protocols()
- *
- * @see messageContact()
- * @see chatWithContact()
- * @see sendFile()
- * @see locate()
- * @see protocols()
- * @see addContact()
- */
- virtual void messageNewContact( const TQString &contactId, const TQString &protocol ) = 0;
-
- /**
- * @brief Start a chat session with the specified contact
- *
- * Applications that do not support a chat mode or when the IM-service
- * of the given contact does not support it, this can also open
- * a normal message input GUI.
- *
- * @param uid the KABC UID you want to chat with
- *
- * @see messageContact()
- * @see messageNewContact()
- * @see sendFile()
- * @see isPresent()
- * @see reachableContacts()
- * @see KABC::Addressee::uid()
- */
- virtual void chatWithContact( const TQString &uid ) = 0;
-
- /**
- * @brief Send a file to the contact
- *
- * Initiates a file transfer with the given contact if possible.
- *
- * Implementations might start the transfer right away, ask the user's
- * permission or just prefill the usual file transfer GUI.
- *
- * @note As sending any file could potentially be a breach of the user's
- * privacy it is recommended to let the user know about it.
- *
- * @param uid the KABC UID you want to send to
- * @param sourceURL a KURL pointing to the file to send
- * @param altFileName an alternate filename describing the file or a
- * description or title
- * @param fileSize file size in bytes
- *
- * @see messageContact()
- * @see messageNewContact()
- * @see chatWithContact()
- * @see isPresent()
- * @see fileTransferContacts()
- * @see KABC::Addressee::uid()
- */
- virtual void sendFile(const TQString &uid, const KURL &sourceURL,
- const TQString &altFileName = TQString::null, uint fileSize = 0) = 0;
-
-// MUTATORS
-// Contact list
- /**
- * @brief Add a new contact given its protocol specific identifier
- *
- * Implementations might add the contact silently, including sending an
- * authorization request if necessary, ask the user for confirmation or
- * just prefill the usual contact addingGUI.
- *
- * @param contactId the protocol specific identifier for the contact
- * e.g. UIN for ICQ, screenname for AIM, nick for IRC
- * @param protocol the IM protocol/service to use. See protocols()
- * @return whether the add succeeded. @c false may signal already present,
- * protocol not supported, or add operation not supported.
- *
- * @see locate()
- * @see protocols()
- * @see messageNewContact()
- */
- virtual bool addContact( const TQString &contactId, const TQString &protocol ) = 0;
-
-// SIGNALS
-k_dcop_signals:
- /**
- * @brief Indicates that a contact's presence has changed
- *
- * Notifies connected DCOP receivers about a change in a contact's
- * presence.
- *
- * Implementations just have to call this method with the appropriate
- * values to get the DCOP signal emitted.
- *
- * @param uid the KABC UID whose presence changed
- * @param appId the DCOP application ID of the program the signal
- * originates from
- * @param presence the new presence's numeric value. See presenceStatus()
- *
- * @see presenceStatus()
- * @see KABC::Addressee::uid()
- * @see DCOPClient::appId()
- */
- void contactPresenceChanged( TQString uid, TQCString appId, int presence );
-};
-
-#endif
-
-
-
-/*
- * Local variables:
- * c-indentation-style: k&r
- * c-basic-offset: 8
- * indent-tabs-mode: t
- * End:
- */
-// vim: set noet ts=4 sts=4 sw=4:
-
diff --git a/interfaces/kimproxy/library/CMakeLists.txt b/interfaces/kimproxy/library/CMakeLists.txt
deleted file mode 100644
index 347e552a5..000000000
--- a/interfaces/kimproxy/library/CMakeLists.txt
+++ /dev/null
@@ -1,51 +0,0 @@
-#################################################
-#
-# (C) 2010 Serghei Amelian
-# serghei (DOT) amelian (AT) gmail.com
-#
-# Improvements and feedback are welcome
-#
-# This file is released under GPL >= 2
-#
-#################################################
-
-add_subdirectory( icons )
-
-include_directories(
- ${TQT_INCLUDE_DIRS}
- ${CMAKE_CURRENT_BINARY_DIR}
- ${CMAKE_BINARY_DIR}/tdecore
- ${CMAKE_SOURCE_DIR}/dcop
- ${CMAKE_SOURCE_DIR}/tdecore
- ${CMAKE_SOURCE_DIR}/tdeui
- ${CMAKE_SOURCE_DIR}/kio/kio
-)
-
-link_directories(
- ${TQT_LIBRARY_DIRS}
-)
-
-
-##### headers ###################################
-
-install( FILES
- kimproxy.h kimproxyiface.h
- DESTINATION ${INCLUDE_INSTALL_DIR} )
-
-
-##### kimproxy ##################################
-
-set( target kimproxy )
-
-set( ${target}_SRCS
- kimproxy.cpp kimproxyiface.skel
- ${CMAKE_SOURCE_DIR}/interfaces/kimproxy/interface/kimiface.stub
-)
-
-tde_add_library( ${target} SHARED AUTOMOC
- SOURCES ${${target}_SRCS}
- VERSION 0.0.0
- LINK kio-shared
- DESTINATION ${LIB_INSTALL_DIR}
- DEPENDENCIES dcopidl
-)
diff --git a/interfaces/kimproxy/library/Makefile.am b/interfaces/kimproxy/library/Makefile.am
deleted file mode 100644
index 94f2974ac..000000000
--- a/interfaces/kimproxy/library/Makefile.am
+++ /dev/null
@@ -1,26 +0,0 @@
-SUBDIRS = icons
-
-INCLUDES = $(all_includes)
-
-noinst_HEADERS = kimproxyiface.h
-
-METASOURCES = AUTO
-
-AM_CPPFLAGS = $(all_includes)
-
-messages: rc.cpp
- $(XGETTEXT) *.cpp -o $(podir)/kimproxy.pot
-
-kimproxyincludedir = $(includedir)
-kimproxyinclude_HEADERS = kimproxy.h kimproxyiface.h
-
-lib_LTLIBRARIES = libkimproxy.la
-libkimproxy_la_LDFLAGS = -no-undefined $(all_libraries)
-libkimproxy_la_LIBADD = $(LIB_KIO) $(LIB_QT) $(LIB_TDECORE) $(top_builddir)/dcop/libDCOP.la $(LIB_TDEUI)
-libkimproxy_la_SOURCES = kimproxy.cpp kimiface.stub kimproxyiface.skel
-
-kimiface_DIR = $(top_srcdir)/interfaces/kimproxy/interface
-
-include $(top_srcdir)/admin/Doxyfile.am
-DOXYGEN_REFERENCES = kabc dcop
-
diff --git a/interfaces/kimproxy/library/icons/CMakeLists.txt b/interfaces/kimproxy/library/icons/CMakeLists.txt
deleted file mode 100644
index ac95aa58c..000000000
--- a/interfaces/kimproxy/library/icons/CMakeLists.txt
+++ /dev/null
@@ -1,13 +0,0 @@
-#################################################
-#
-# (C) 2010 Serghei Amelian
-# serghei (DOT) amelian (AT) gmail.com
-#
-# Improvements and feedback are welcome
-#
-# This file is released under GPL >= 2
-#
-#################################################
-
-tde_install_icons( )
-
diff --git a/interfaces/kimproxy/library/icons/Makefile.am b/interfaces/kimproxy/library/icons/Makefile.am
deleted file mode 100644
index a4b97f06a..000000000
--- a/interfaces/kimproxy/library/icons/Makefile.am
+++ /dev/null
@@ -1 +0,0 @@
-KDE_ICON=AUTO
diff --git a/interfaces/kimproxy/library/icons/cr16-action-presence_away.png b/interfaces/kimproxy/library/icons/cr16-action-presence_away.png
deleted file mode 100644
index f96a9c65f..000000000
--- a/interfaces/kimproxy/library/icons/cr16-action-presence_away.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr16-action-presence_offline.png b/interfaces/kimproxy/library/icons/cr16-action-presence_offline.png
deleted file mode 100644
index f5c53d711..000000000
--- a/interfaces/kimproxy/library/icons/cr16-action-presence_offline.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr16-action-presence_online.png b/interfaces/kimproxy/library/icons/cr16-action-presence_online.png
deleted file mode 100644
index 6cb52496b..000000000
--- a/interfaces/kimproxy/library/icons/cr16-action-presence_online.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr16-action-presence_unknown.png b/interfaces/kimproxy/library/icons/cr16-action-presence_unknown.png
deleted file mode 100644
index 290bc852a..000000000
--- a/interfaces/kimproxy/library/icons/cr16-action-presence_unknown.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr32-action-presence_away.png b/interfaces/kimproxy/library/icons/cr32-action-presence_away.png
deleted file mode 100644
index 086184582..000000000
--- a/interfaces/kimproxy/library/icons/cr32-action-presence_away.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr32-action-presence_offline.png b/interfaces/kimproxy/library/icons/cr32-action-presence_offline.png
deleted file mode 100644
index caadb14d4..000000000
--- a/interfaces/kimproxy/library/icons/cr32-action-presence_offline.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr32-action-presence_online.png b/interfaces/kimproxy/library/icons/cr32-action-presence_online.png
deleted file mode 100644
index 41e79ad9d..000000000
--- a/interfaces/kimproxy/library/icons/cr32-action-presence_online.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr32-action-presence_unknown.png b/interfaces/kimproxy/library/icons/cr32-action-presence_unknown.png
deleted file mode 100644
index 52ab79ed5..000000000
--- a/interfaces/kimproxy/library/icons/cr32-action-presence_unknown.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr48-action-presence_away.png b/interfaces/kimproxy/library/icons/cr48-action-presence_away.png
deleted file mode 100644
index 58e62c1d3..000000000
--- a/interfaces/kimproxy/library/icons/cr48-action-presence_away.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr48-action-presence_offline.png b/interfaces/kimproxy/library/icons/cr48-action-presence_offline.png
deleted file mode 100644
index b69630f33..000000000
--- a/interfaces/kimproxy/library/icons/cr48-action-presence_offline.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/icons/cr48-action-presence_online.png b/interfaces/kimproxy/library/icons/cr48-action-presence_online.png
deleted file mode 100644
index 52fdad8f9..000000000
--- a/interfaces/kimproxy/library/icons/cr48-action-presence_online.png
+++ /dev/null
Binary files differ
diff --git a/interfaces/kimproxy/library/kimproxy.cpp b/interfaces/kimproxy/library/kimproxy.cpp
deleted file mode 100644
index 9acfe00d6..000000000
--- a/interfaces/kimproxy/library/kimproxy.cpp
+++ /dev/null
@@ -1,653 +0,0 @@
-/*
- kimproxy.cpp
-
- IM service library for KDE
-
- Copyright (c) 2004 Will Stephenson <[email protected]>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library 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
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#include <tqglobal.h>
-#include <tqpixmapcache.h>
-#include <dcopclient.h>
-#include <kapplication.h>
-#include <kdcopservicestarter.h>
-#include <kdebug.h>
-#include <kmessagebox.h>
-#include <ksimpleconfig.h>
-#include <kiconloader.h>
-#include <kservice.h>
-#include <kservicetype.h>
-
-#include "kimiface_stub.h"
-
-#include "kimproxy.h"
-
-static KStaticDeleter<KIMProxy> _staticDeleter;
-
-KIMProxy * KIMProxy::s_instance = 0L;
-
-struct AppPresenceCurrent
-{
- TQCString appId;
- int presence;
-};
-
-class ContactPresenceListCurrent : public TQValueList<AppPresenceCurrent>
-{
- public:
- // return value indicates if the supplied parameter was better than any existing presence
- bool update( const AppPresenceCurrent );
- AppPresenceCurrent best();
-};
-
-
-struct KIMProxy::Private
-{
- DCOPClient * dc;
- // list of the strings in use by KIMIface
- TQStringList presence_strings;
- // list of the icon names in use by KIMIface
- TQStringList presence_icons;
- // map of presences
- PresenceStringMap presence_map;
-};
-
-bool ContactPresenceListCurrent::update( AppPresenceCurrent ap )
-{
- if ( isEmpty() )
- {
- append( ap );
- return true;
- }
-
- bool bestChanged = false;
- AppPresenceCurrent best;
- best.presence = -1;
- ContactPresenceListCurrent::iterator it = begin();
- const ContactPresenceListCurrent::iterator itEnd = end();
- ContactPresenceListCurrent::iterator existing = itEnd;
-
- while ( it != itEnd )
- {
- if ( (*it).presence > best.presence )
- best = (*it);
- if ( (*it).appId == ap.appId )
- existing = it;
- ++it;
- }
-
- if ( ap.presence > best.presence ||
- best.appId == ap.appId )
- bestChanged = true;
-
- if ( existing != itEnd )
- {
- remove( existing );
- append( ap );
- }
- return bestChanged;
-}
-
-AppPresenceCurrent ContactPresenceListCurrent::best()
-{
- AppPresenceCurrent best;
- best.presence = -1;
- ContactPresenceListCurrent::iterator it = begin();
- const ContactPresenceListCurrent::iterator itEnd = end();
- while ( it != itEnd )
- {
- if ( (*it).presence > best.presence )
- best = (*it);
- ++it;
- }
- // if it's still -1 here, we have no presence data, so we return Unknown
- if ( best.presence == -1 )
- best.presence = 0;
- return best;
-}
-
-// int bestPresence( AppPresence* ap )
-// {
-// Q_ASSERT( ap );
-// AppPresence::const_iterator it;
-// it = ap->begin();
-// int best = 0; // unknown
-// if ( it != ap->end() )
-// {
-// best = it.data();
-// ++it;
-// for ( ; it != ap->end(); ++it )
-// {
-// if ( it.data() > best )
-// best = it.data();
-// }
-// }
-// return best;
-// }
-//
-// TQCString bestAppId( AppPresence* ap )
-// {
-// Q_ASSERT( ap );
-// AppPresence::const_iterator it;
-// TQCString bestAppId;
-// it = ap->begin();
-// if ( it != ap->end() )
-// {
-// int best = it.data();
-// bestAppId = it.key();
-// ++it;
-// for ( ; it != ap->end(); ++it )
-// {
-// if ( it.data() > best )
-// {
-// best = it.data();
-// bestAppId = it.key();
-// }
-// }
-// }
-// return bestAppId;
-// }
-
-KIMProxy * KIMProxy::instance( DCOPClient * client )
-{
- if ( client )
- {
- if ( !s_instance )
- _staticDeleter.setObject( s_instance, new KIMProxy( client ) );
- return s_instance;
- }
- else
- return 0L;
-}
-
-KIMProxy::KIMProxy( DCOPClient* dc ) : DCOPObject( "KIMProxyIface" ), TQObject(), d( new Private )
-{
- m_im_client_stubs.setAutoDelete( true );
-
- d->dc = dc;
- m_initialized = false;
- connect( d->dc, TQT_SIGNAL( applicationRemoved( const TQCString& ) ) , this, TQT_SLOT( unregisteredFromDCOP( const TQCString& ) ) );
- connect( d->dc, TQT_SIGNAL( applicationRegistered( const TQCString& ) ) , this, TQT_SLOT( registeredToDCOP( const TQCString& ) ) );
- d->dc->setNotifications( true );
-
- d->presence_strings.append( "Unknown" );
- d->presence_strings.append( "Offline" );
- d->presence_strings.append( "Connecting" );
- d->presence_strings.append( "Away" );
- d->presence_strings.append( "Online" );
-
- d->presence_icons.append( "presence_unknown" );
- d->presence_icons.append( "presence_offline" );
- d->presence_icons.append( "presence_connecting" );
- d->presence_icons.append( "presence_away" );
- d->presence_icons.append( "presence_online" );
-
- //TQCString senderApp = "Kopete";
- //TQCString senderObjectId = "KIMIface";
- TQCString method = "contactPresenceChanged( TQString, TQCString, int )";
- //TQCString receiverObjectId = "KIMProxyIface";
-
- // FIXME: make this work when the sender object id is set to KIMIFace
- if ( !connectDCOPSignal( 0, 0, method, method, false ) )
- kdWarning() << "Couldn't connect DCOP signal. Won't receive any status notifications!" << endl;
-}
-
-KIMProxy::~KIMProxy( )
-{
- //d->dc->setNotifications( false );
-}
-
-bool KIMProxy::initialize()
-{
- if ( !m_initialized )
- {
- m_initialized = true; // we should only do this once, as registeredToDCOP() will catch any new starts
- // So there is no error from a failed query when using tdelibs 3.2, which don't have this servicetype
- if ( KServiceType::serviceType( IM_SERVICE_TYPE ) )
- {
- //kdDebug( 790 ) << k_funcinfo << endl;
- TQCString dcopObjectId = "KIMIface";
-
- // see what apps implementing our service type are out there
- KService::List offers = KServiceType::offers( IM_SERVICE_TYPE );
- KService::List::iterator offer;
- typedef TQValueList<TQCString> QCStringList;
- QCStringList registeredApps = d->dc->registeredApplications();
- QCStringList::iterator app;
- const QCStringList::iterator end = registeredApps.end();
- // for each registered app
- for ( app = registeredApps.begin(); app != end; ++app )
- {
- //kdDebug( 790 ) << " considering: " << *app << endl;
- //for each offer
- for ( offer = offers.begin(); offer != offers.end(); ++offer )
- {
- TQCString dcopService = (*offer)->property("X-DCOP-ServiceName").toString().latin1();
- if ( !dcopService.isEmpty() )
- {
- //kdDebug( 790 ) << " is it: " << dcopService << "?" << endl;
- // get the application name ( minus any process ID )
- TQCString instanceName = (*app).left( dcopService.length() );
- // if the application implements the dcop service, add it
- if ( instanceName == dcopService )
- {
- m_apps_available = true;
- //kdDebug( 790 ) << " app name: " << (*offer)->name() << ", has instance " << *app << ", dcopService: " << dcopService << endl;
- if ( !m_im_client_stubs.find( dcopService ) )
- {
- kdDebug( 790 ) << "App " << *app << ", dcopObjectId " << dcopObjectId << " found, using it for presence info." << endl;
- m_im_client_stubs.insert( *app, new KIMIface_stub( d->dc, *app, dcopObjectId ) );
- pollApp( *app );
- }
- }
- }
- }
- }
- }
- }
- return !m_im_client_stubs.isEmpty();
-}
-
-void KIMProxy::registeredToDCOP( const TQCString& appId )
-{
- //kdDebug( 790 ) << k_funcinfo << " appId '" << appId << "'" << endl;
- // check that appId implements our service
- // if the appId ends with a number, i.e. a pid like in foobar-12345,
- if ( appId.isEmpty() )
- return;
-
- bool newApp = false;
- // get an up to date list of offers in case a new app was installed
- // and check each of the offers that implement the service type we're looking for,
- // to see if any of them are the app that just registered
- const KService::List offers = KServiceType::offers( IM_SERVICE_TYPE );
- KService::List::const_iterator it;
- for ( it = offers.begin(); it != offers.end(); ++it )
- {
- TQCString dcopObjectId = "KIMIface";
- TQCString dcopService = (*it)->property("X-DCOP-ServiceName").toString().latin1();
- if ( appId.left( dcopService.length() ) == dcopService )
- {
- // if it's not already known, insert it
- if ( !m_im_client_stubs.find( appId ) )
- {
- newApp = true;
- kdDebug( 790 ) << "App: " << appId << ", dcopService: " << dcopService << " started, using it for presence info."<< endl;
- m_im_client_stubs.insert( appId, new KIMIface_stub( d->dc, appId, dcopObjectId ) );
- }
- }
- //else
- // kdDebug( 790 ) << "App doesn't implement our ServiceType" << endl;
- }
- //if ( newApp )
- // emit sigPresenceInfoExpired();
-}
-
-void KIMProxy::unregisteredFromDCOP( const TQCString& appId )
-{
- //kdDebug( 790 ) << k_funcinfo << appId << endl;
- if ( m_im_client_stubs.find( appId ) )
- {
- kdDebug( 790 ) << appId << " quit, removing its presence info." << endl;
-
- PresenceStringMap::Iterator it = d->presence_map.begin();
- const PresenceStringMap::Iterator end = d->presence_map.end();
- for ( ; it != end; ++it )
- {
- ContactPresenceListCurrent list = it.data();
- ContactPresenceListCurrent::iterator cpIt = list.begin();
- while( cpIt != list.end() )
- {
- ContactPresenceListCurrent::iterator gone = cpIt++;
- if ( (*gone).appId == appId )
- {
- list.remove( gone );
- }
- }
- }
- m_im_client_stubs.remove( appId );
- emit sigPresenceInfoExpired();
- }
-}
-
-void KIMProxy::contactPresenceChanged( TQString uid, TQCString appId, int presence )
-{
- // update the presence map
- //kdDebug( 790 ) << k_funcinfo << "uid: " << uid << " appId: " << appId << " presence " << presence << endl;
- ContactPresenceListCurrent current;
- current = d->presence_map[ uid ];
- //kdDebug( 790 ) << "current best presence from : " << current.best().appId << " is: " << current.best().presence << endl;
- AppPresenceCurrent newPresence;
- newPresence.appId = appId;
- newPresence.presence = presence;
-
- if ( current.update( newPresence ) )
- {
- d->presence_map.insert( uid, current );
- emit sigContactPresenceChanged( uid );
- }
-}
-
-int KIMProxy::presenceNumeric( const TQString& uid )
-{
- AppPresenceCurrent ap;
- ap.presence = 0;
- if ( initialize() )
- {
- ContactPresenceListCurrent presence = d->presence_map[ uid ];
- ap = presence.best();
- }
- return ap.presence;
-}
-
-TQString KIMProxy::presenceString( const TQString& uid )
-{
- AppPresenceCurrent ap;
- ap.presence = 0;
- if ( initialize() )
- {
- ContactPresenceListCurrent presence = d->presence_map[ uid ];
- ap = presence.best();
- }
- if ( ap.appId.isEmpty() )
- return TQString::null;
- else
- return d->presence_strings[ ap.presence ];
-}
-
-TQPixmap KIMProxy::presenceIcon( const TQString& uid )
-{
- AppPresenceCurrent ap;
- ap.presence = 0;
- if ( initialize() )
- {
- ContactPresenceListCurrent presence = d->presence_map[ uid ];
- ap = presence.best();
- }
- if ( ap.appId.isEmpty() )
- {
- //kdDebug( 790 ) << k_funcinfo << "returning a null TQPixmap because we were asked for an icon for a uid we know nothing about" << endl;
- return TQPixmap();
- }
- else
- {
- //kdDebug( 790 ) << k_funcinfo << "returning this: " << d->presence_icons[ ap.presence ] << endl;
- return SmallIcon( d->presence_icons[ ap.presence ]);
- }
-}
-
-TQStringList KIMProxy::allContacts()
-{
- TQStringList value = d->presence_map.keys();
- return value;
-}
-
-TQStringList KIMProxy::reachableContacts()
-{
- TQStringList value;
-
- if ( initialize() )
- {
- TQDictIterator<KIMIface_stub> it( m_im_client_stubs );
- for ( ; it.current(); ++it )
- {
- value += it.current()->reachableContacts( );
- }
- }
- return value;
-}
-
-TQStringList KIMProxy::onlineContacts()
-{
- TQStringList value;
- PresenceStringMap::iterator it = d->presence_map.begin();
- const PresenceStringMap::iterator end= d->presence_map.end();
- for ( ; it != end; ++it )
- if ( it.data().best().presence > 2 /*Better than Connecting, ie Away or Online*/ )
- value.append( it.key() );
-
- return value;
-}
-
-TQStringList KIMProxy::fileTransferContacts()
-{
- TQStringList value;
-
- if ( initialize() )
- {
- TQDictIterator<KIMIface_stub> it( m_im_client_stubs );
- for ( ; it.current(); ++it )
- {
- value += it.current()->fileTransferContacts( );
- }
- }
- return value;
-}
-
-bool KIMProxy::isPresent( const TQString& uid )
-{
- return ( !d->presence_map[ uid ].isEmpty() );
-}
-
-TQString KIMProxy::displayName( const TQString& uid )
-{
- TQString name;
- if ( initialize() )
- {
- if ( KIMIface_stub* s = stubForUid( uid ) )
- name = s->displayName( uid );
- }
- //kdDebug( 790 ) << k_funcinfo << name << endl;
- return name;
-}
-
-bool KIMProxy::canReceiveFiles( const TQString & uid )
-{
- if ( initialize() )
- {
- if ( KIMIface_stub* s = stubForUid( uid ) )
- return s->canReceiveFiles( uid );
- }
- return false;
-}
-
-bool KIMProxy::canRespond( const TQString & uid )
-{
- if ( initialize() )
- {
- if ( KIMIface_stub* s = stubForUid( uid ) )
- return s->canRespond( uid );
- }
- return false;
-}
-
-TQString KIMProxy::context( const TQString & uid )
-{
- if ( initialize() )
- {
- if ( KIMIface_stub* s = stubForUid( uid ) )
- return s->context( uid );
- }
- return TQString::null;
-}
-
-void KIMProxy::chatWithContact( const TQString& uid )
-{
- if ( initialize() )
- {
- if ( KIMIface_stub* s = stubForUid( uid ) )
- {
- kapp->updateRemoteUserTimestamp( s->app() );
- s->chatWithContact( uid );
- }
- }
- return;
-}
-
-void KIMProxy::messageContact( const TQString& uid, const TQString& message )
-{
- if ( initialize() )
- {
- if ( KIMIface_stub* s = stubForUid( uid ) )
- {
- kapp->updateRemoteUserTimestamp( s->app() );
- s->messageContact( uid, message );
- }
- }
- return;
-}
-
-void KIMProxy::sendFile(const TQString &uid, const KURL &sourceURL, const TQString &altFileName, uint fileSize )
-{
- if ( initialize() )
- {
- TQDictIterator<KIMIface_stub> it( m_im_client_stubs );
- for ( ; it.current(); ++it )
- {
- if ( it.current()->canReceiveFiles( uid ) )
- {
- kapp->updateRemoteUserTimestamp( it.current()->app() );
- it.current()->sendFile( uid, sourceURL, altFileName, fileSize );
- break;
- }
- }
- }
- return;
-}
-
-bool KIMProxy::addContact( const TQString &contactId, const TQString &protocol )
-{
- if ( initialize() )
- {
- if ( KIMIface_stub* s = stubForProtocol( protocol ) )
- return s->addContact( contactId, protocol );
- }
- return false;
-}
-
-TQString KIMProxy::locate( const TQString & contactId, const TQString & protocol )
-{
- if ( initialize() )
- {
- if ( KIMIface_stub* s = stubForProtocol( protocol ) )
- return s->locate( contactId, protocol );
- }
- return TQString::null;
-}
-
-bool KIMProxy::imAppsAvailable()
-{
- return ( !m_im_client_stubs.isEmpty() );
-}
-
-bool KIMProxy::startPreferredApp()
-{
- TQString preferences = TQString("[X-DCOP-ServiceName] = '%1'").arg( preferredApp() );
- // start/find an instance of DCOP/InstantMessenger
- TQString error;
- TQCString dcopService;
- // Get a preferred IM client.
- // The app will notify itself to us using registeredToDCOP, so we don't need to record a stub for it here
- // FIXME: error in preferences, see debug output
- preferences = TQString::null;
- int result = KDCOPServiceStarter::self()->findServiceFor( IM_SERVICE_TYPE, TQString::null, preferences, &error, &dcopService );
-
- kdDebug( 790 ) << k_funcinfo << "error was: " << error << ", dcopService: " << dcopService << endl;
-
- return ( result == 0 );
-}
-
-
-void KIMProxy::pollAll( const TQString &uid )
-{
-/* // We only need to call this function if we don't have any data at all
- // otherwise, the data will be kept fresh by received presence change
- // DCOP signals
- if ( !d->presence_map.contains( uid ) )
- {
- AppPresence *presence = new AppPresence();
- // record current presence from known clients
- TQDictIterator<KIMIface_stub> it( m_im_client_stubs );
- for ( ; it.current(); ++it )
- {
- presence->insert( it.currentKey().ascii(), it.current()->presenceStatus( uid ) ); // m_im_client_stubs has qstring keys...
- }
- d->presence_map.insert( uid, presence );
- }*/
-}
-
-void KIMProxy::pollApp( const TQCString & appId )
-{
- //kdDebug( 790 ) << k_funcinfo << endl;
- KIMIface_stub * appStub = m_im_client_stubs[ appId ];
- TQStringList contacts = m_im_client_stubs[ appId ]->allContacts();
- TQStringList::iterator it = contacts.begin();
- TQStringList::iterator end = contacts.end();
- for ( ; it != end; ++it )
- {
- ContactPresenceListCurrent current = d->presence_map[ *it ];
- AppPresenceCurrent ap;
- ap.appId = appId;
- ap.presence = appStub->presenceStatus( *it );
- current.append( ap );
-
- d->presence_map.insert( *it, current );
- if ( current.update( ap ) )
- emit sigContactPresenceChanged( *it );
- //kdDebug( 790 ) << " uid: " << *it << " presence: " << ap.presence << endl;
- }
-}
-
-KIMIface_stub * KIMProxy::stubForUid( const TQString &uid )
-{
- // get best appPresence
- AppPresenceCurrent ap = d->presence_map[ uid ].best();
- // look up the presence string from that app
- return m_im_client_stubs.find( ap.appId );
-}
-
-KIMIface_stub * KIMProxy::stubForProtocol( const TQString &protocol)
-{
- KIMIface_stub * app;
- // see if the preferred client supports this protocol
- TQString preferred = preferredApp();
- if ( ( app = m_im_client_stubs.find( preferred ) ) )
- {
- if ( app->protocols().grep( protocol ).count() > 0 )
- return app;
- }
- // preferred doesn't do this protocol, try the first of the others that says it does
- TQDictIterator<KIMIface_stub> it( m_im_client_stubs );
- for ( ; it.current(); ++it )
- {
- if ( it.current()->protocols().grep( protocol ).count() > 0 )
- return it.current();
- }
- return 0L;
-}
-
-TQString KIMProxy::preferredApp()
-{
- KConfig *store = new KSimpleConfig( IM_CLIENT_PREFERENCES_FILE );
- store->setGroup( IM_CLIENT_PREFERENCES_SECTION );
- TQString preferredApp = store->readEntry( IM_CLIENT_PREFERENCES_ENTRY );
- //kdDebug( 790 ) << k_funcinfo << "found preferred app: " << preferredApp << endl;
- return preferredApp;
-}
-
-#include "kimproxy.moc"
diff --git a/interfaces/kimproxy/library/kimproxy.h b/interfaces/kimproxy/library/kimproxy.h
deleted file mode 100644
index d4312b341..000000000
--- a/interfaces/kimproxy/library/kimproxy.h
+++ /dev/null
@@ -1,654 +0,0 @@
-/*
- kimproxy.h
-
- IM service library for KDE
-
- Copyright (c) 2004 Will Stephenson <[email protected]>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library 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
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#ifndef KIMPROXY_H
-#define KIMPROXY_H
-
-#include <tqdict.h>
-#include <tqmap.h>
-#include <tqptrdict.h>
-#include <tqstringlist.h>
-
-
-#define IM_SERVICE_TYPE "DCOP/InstantMessenger"
-#define IM_CLIENT_PREFERENCES_FILE "default_components"
-#define IM_CLIENT_PREFERENCES_SECTION "InstantMessenger"
-#define IM_CLIENT_PREFERENCES_ENTRY "imClient"
-
-#include "kimproxyiface.h"
-
-class DCOPClient;
-class KIMIface_stub;
-class KURL;
-class ContactPresenceListCurrent;
-
-/** FIXME: remove for KDE4, binary compability again. */
-typedef TQMap<TQCString, int> AppPresence; // appId->presence; contains all applications' ideas of a user's presence
-typedef TQDict<AppPresence> PresenceMap; // uid->AppPresence; contains a AppPresences for all users
-/** FIXME: remove presenceMap and call this presenceMap in KDE4. This hack is for binary compatibility */
-typedef TQMap<TQString, ContactPresenceListCurrent> PresenceStringMap;
-
-/**
- * @brief Provides access to instant messenger programs which implement KDE's
- * instant messanger interface KIMIface
- *
- * This class provides an easy-to-use interface to all running instant
- * messengers or chat programs that implement KIMIface.
- *
- * It works simultaneously with any running programs that implement the
- * ServiceType @c DCOP/InstantMessenger.
- *
- * IM-contacts are identified using unique identifier strings (UID) used by
- * KDE's address book framework KABC.
- * However the use of the address book API is optional, KIMProxy provides
- * methods to fetch lists of available contact UIDs from the applications.
- * If a UID is reachable with more than one program, KIMProxy aggregates the
- * available information and presents the 'best' presence. For example, for a
- * contact who can be seen to be @c Away in @c IRC on program A but @c Online
- * using @c ICQ on program B, the information from program B will be used.
- *
- * KIMProxy is designed for simple information in a wide number of cases, not
- * for detailed messaging.
- *
- * The class is implemented as a singleton, so whenever you need access to
- * one of its methods, just retrieve the single instance using instance().
- * The following code snippet demonstrated how to send a message to all
- * reachable IM-contacts:
- * @code
- * // get proxy instance
- * KIMProxy* proxy = KIMProxy::instance();
- *
- * // check if there are suitable applications reachable
- * if (!proxy->initialize()) return;
- *
- * TQString message = "Hi!\nHow are you on this wonderful day?";
- *
- * // iterate over the list of reachable contacts
- * TQStringList reachableContacts = proxy->reachableContacts();
- * for (TQStringList::const_iterator it = reachableContacts.begin();
- * it != reachableContacts.end(); ++it)
- * {
- proxy->messageContact(*it, message);
- * }
- * @endcode
- *
- * @note While it is possible to communicate with each of those application's
- * by DCOP using KIMProxy has the advantage of communicating with all
- * applications simultaneously and thus getting an augmented view of
- * availability, capability and presence (online status) of IM-contacts.
- *
- * @see KIMIface
- * @see KABC::AddressBook
- * @see KABC::Addressee
- *
- * @since 3.3
- * @author Will Stephenson <[email protected]>
- */
-class KIMPROXY_EXPORT KIMProxy : public TQObject, virtual public KIMProxyIface
-{
- Q_OBJECT
- struct Private;
-
- template<class> friend class KStaticDeleter;
- ~KIMProxy();
-
- public:
- /**
- * @brief Obtain an instance of KIMProxy
- *
- * Creates a new instance if it is called for the first time.
- * Call initialize() to check if there are applications available for
- * communication.
- *
- * @note KIMProxy uses DCOPClient::setNotifications() to make sure
- * it updates its information about IM applications it interacts with,
- * e.g. that it gets notified about newly available applications or
- * about applications exiting
- *
- * @param client your application's DCOP client
- * @return the singleton instance of this class
- */
- static KIMProxy * instance( DCOPClient * client );
-
- /**
- * @brief Get the proxy ready to connect
- *
- * Discover any running IM clients and setup communication handlers for
- * them. The list of available clients is updated automatically
- * through notification about added or removed DCOP applications as
- * provided by DCOPClient.
- *
- * It is safe to call this method more than once, initialization only
- * occurs at the first time.
- *
- * @return whether the proxy is ready to use.
- * @c false if there are no suitable apps running
- */
- bool initialize();
-
- /**
- * @brief Obtain a list of IM-contacts known to IM-applications
- *
- * Returns a list of KABC UIDs gathered by merging the lists of
- * each application the proxy can communicate with.
- * The method uses cached information to make it fast and not
- * require actually communicating with the applications every time
- * it is called.
- *
- * @return a list of KABC UIDs known to any IM-application
- *
- * @see reachableContacts()
- * @see onlineContacts()
- * @see fileTransferContacts()
- * @see isPresent()
- * @see KABC::Addressee::uid()
- */
- TQStringList allContacts();
-
- /**
- * @brief Obtain a list of IM-contacts that are currently reachable
- *
- * Returns a list of KABC UIDs gathered by merging the lists of
- * each application the proxy can communicate with.
- *
- * @return a list of KABC UIDs who can receive a message, even if offline
- *
- * @see allContacts()
- * @see onlineContacts()
- * @see fileTransferContacts()
- * @see messageContact()
- * @see KABC::Addressee::uid()
- */
- TQStringList reachableContacts();
-
- /**
- * @brief Obtain a list of IM-contacts that are currently online
- *
- * Returns a list of KABC UIDs gathered by merging the lists of
- * each application the proxy can communicate with.
- * The method uses cached information to make it fast and not
- * require actually communicating with the applications every time
- * it is called.
- *
- * @return a list of KABC UIDs who are online with unspecified presence
- *
- * @see allContacts()
- * @see reachableContacts()
- * @see fileTransferContacts()
- * @see messageContact()
- * @see chatWithContact()
- * @see KABC::Addressee::uid()
- */
- TQStringList onlineContacts();
-
- /**
- * @brief Obtain a list of IM-contacts who may receive file transfers
- *
- * Returned IM-contacts might not be capable of receiving file
- * tranfers due to limitations of their clients or because they are
- * behind a firewall.
- * KIMProxy doesn't have the possibilities to discover this and will
- * list them as well.
- *
- * Returns a list of KABC UIDs gathered by merging the lists of
- * each application the proxy can communicate with.
- *
- * @return a list of KABC UIDs capable of file transfer
- *
- * @see allContacts()
- * @see reachableContacts()
- * @see onlineContacts()
- * @see canReceiveFiles()
- * @see KABC::Addressee::uid()
- */
- TQStringList fileTransferContacts();
-
- /**
- * @brief Confirm if a given contact is known to the proxy
- *
- * A contact is known to the proxy if it is know to at least one
- * IM-application the proxy is communicating with.
- *
- * The method uses cached information to make it fast and not
- * require actually communicating with the applications every time
- * it is called.
- *
- * @param uid the KABC UID you are interested in
- * @return whether any IM-program knows of this KABC UID
- *
- * @see allContacts()
- * @see presenceString()
- * @see presenceNumeric()
- * @see KABC::Addressee::uid()
- */
- bool isPresent( const TQString& uid );
-
- /**
- * @brief Obtain the proxy's idea of the contact's display name
- *
- * If the given KABC UID is known to more than one IM-application
- * the result of the application which has the best presence for the
- * contact is taken.
- * For example if a contact is @c Online on ICQ and @c Away on AIM, the
- * value returned by the application providing ICQ is taken.
- *
- * Useful if KABC lookups may be too slow.
- *
- * @param uid the KABC UID you are interested in
- * @return the corresponding display name or TQString:null if the
- * UID is unknown
- *
- * @see isPresent()
- * @see presenceString()
- * @see presenceNumeric()
- * @see KABC::Addressee::uid()
- */
- TQString displayName( const TQString& uid );
-
- /**
- * @brief Obtain the IM presence as a number for the specified contact
- *
- * Returns one of the following values depending on the given contact's
- * presence:
- * - 0 - @c Unknown: for contacts where you can not use any of the
- * other values
- *
- * - 1 - @c Offline: for contacts that are offline, i.e. not connected
- * to their IM-service.
- *
- * - 2 - @c Connecting
- *
- * - 3 - @c Away: for contacts that are connected to their IM-service
- * but not @c Online
- *
- * - 4 - @c Online
- *
- * If the given KABC UID is known to more than one IM-application
- * the result of the application which has the best presence for the
- * contact is taken.
- * For example if a contact is @c Online on ICQ and Away on AIM, the
- * value returned by the application providing ICQ is taken.
- *
- * The method uses cached information to make it fast and not
- * require actually communicating with the applications every time
- * it is called.
- *
- * @param uid the KABC UID you want the presence for
- * @return a numeric representation of presence - currently one of
- * 0 (Unknown), 1 (Offline), 2 (Connecting), 3 (Away),
- * 4 (Online). Returns 0 if the given UID is unknown
- *
- * @see isPresent()
- * @see presenceString()
- * @see presenceIcon()
- * @see KIMIface::presenceStatus()
- * @see KABC::Addressee::uid()
- */
- int presenceNumeric( const TQString& uid );
-
- /**
- * @brief Obtain the IM presence as a i18ned string for the specified
- * contact
- *
- * The presence string is one of the following:
- * - i18n("Unknown")
- * - i18n("Offline")
- * - i18n("Connecting")
- * - i18n("Away")
- * - i18n("Online")
- *
- * If the given KABC UID is known to more than one IM-application
- * the result of the application which has the best presence for the
- * contact is taken.
- * For example if a contact is @c Online on ICQ and Away on AIM, the
- * value returned by the application providing ICQ is taken.
- *
- * @note The presence string is created based on the numerical
- * presence value returned by the applications. It currently
- * does not return the presence strings used by the applications.
- *
- * The method uses cached information to make it fast and not
- * require actually communicating with the applications every time
- * it is called.
- *
- * @param uid the KABC UID you want the presence for
- * @return the i18ned string describing the contact's presence or
- * TQString::null if the UID is unknown
- *
- * @see isPresent()
- * @see presenceNumeric()
- * @see presenceIcon()
- * @see KABC::Addressee::uid()
- */
- TQString presenceString( const TQString& uid );
-
- /**
- * @brief Obtain the icon representing the IM presence for the
- * specified contact
- *
- * If the given KABC UID is known to more than one IM-application
- * the result of the application which has the best presence for the
- * contact is taken.
- * For example if a contact is @c Online on ICQ and Away on AIM, the
- * value returned by the application providing ICQ is taken.
- *
- * @note The presence icon is chosen based on the numerical
- * presence value returned by the applications. It currently
- * does not return the presence icon used by the applications.
- *
- * The method uses cached information to make it fast and not
- * require actually communicating with the applications every time
- * it is called.
- *
- * @param uid the KABC UID you want the presence icon for
- * @return a pixmap representing the contact's presence or a null
- * pixmap if the contact is unknown. See TQPixmap::isNull()
- *
- * @see isPresent()
- * @see presenceString()
- * @see presenceNumeric()
- * @see KABC::Addressee::uid()
- */
- TQPixmap presenceIcon( const TQString& uid );
-
- /**
- * @brief Indicate if a given contact can receive files
- *
- * If the given KABC UID is known to more than one IM-application
- * the result of the application which has the best presence for the
- * contact is taken.
- * For example if a contact is @c Online on ICQ and Away on AIM, the
- * value returned by the application providing ICQ is taken.
- *
- * @param uid the KABC UID you want to the file transfer capability for
- * @return whether the specified contact can receive files
- *
- * @see fileTransferContacts()
- * @see KABC::Addressee::uid()
- */
- bool canReceiveFiles( const TQString & uid );
-
- /**
- * @brief Indicate if a given contact will be able to respond
- *
- * Some media are unidirectional (e.g., sending SMS via a web
- * interface).
- * This refers to the contact's ability to respond as defined by the
- * medium, not by their presence.
- *
- * Someone may appear offline (SMS has no presence) to you but in fact
- * be able to respond.
- *
- * If the given KABC UID is known to more than one IM-application
- * the result of the application which has the best presence for the
- * contact is taken.
- * For example if a contact is @c Online on ICQ and Away on AIM, the
- * value returned by the application providing ICQ is taken.
- *
- * @param uid the KABC UID you are interested in
- * @return whether the specified contact can respond
- *
- * @see isPresent()
- * @see KABC::Addressee::uid()
- */
- bool canRespond( const TQString & uid );
-
- /**
- * @brief Obtain the KABC UID corresponding to the given IM address
- *
- * @param contactId the protocol specific identifier for the contact,
- * e.g. UIN for ICQ, screenname for AIM, nick for IRC
- * @param protocol the IM protocol/service to check.
- * See KIMIface::protocols()
- * @return the KABC UID for the given contact or @c TQString::null if
- * not found or either input stream was empty or the protocol
- * is not supported
- *
- * @see KIMIface::protocols()
- * @see addContact()
- * @see isPresent()
- * @see KABC::Addressee::uid()
- */
- TQString locate( const TQString & contactId, const TQString & protocol );
-
- /**
- * @brief Obtain the given contact's current context (home, work, or
- * any)
- *
- * Not all IM services/protocols support the concept of contexts. If the
- * given UID maps to such a service, @c TQString::null will be returned
- *
- * If the given KABC UID is known to more than one IM-application
- * the result of the application which has the best presence for the
- * contact is taken.
- * For example if a contact is @c Online on ICQ and Away on AIM, the
- * value returned by the application providing ICQ is taken.
- *
- * @param uid the KABC UID you want the context for
- * @return a string describing the context, or @c TQString::null if not
- * supported or if the contact is unknown
- *
- * @see isPresent()
- * @see KABC::Addressee::uid()
- */
- TQString context( const TQString & uid );
-
- /**
- * @brief Start a chat session with the specified contact
- *
- * @param uid the KABC UID you want to chat with
- *
- * @see messageContact()
- * @see sendFile()
- * @see isPresent()
- * @see reachableContacts()
- * @see KABC::Addressee::uid()
- */
- void chatWithContact( const TQString& uid );
-
- /**
- * @brief Send a single message to the specified contact
- *
- * Any response will be handled by the IM client as a normal
- * conversation.
- *
- * @param uid the KABC UID you want to send the message to
- * @param message the message text to send to the contact
- *
- * @see chatWithContact()
- * @see sendFile()
- * @see isPresent()
- * @see reachableContacts()
- * @see KABC::Addressee::uid()
- */
- void messageContact( const TQString& uid, const TQString& message );
-
- /**
- * @brief Send a file to the contact
- *
- * Initiates a file transfer with the given contact if possible.
- *
- * @param uid the KABC UID you want to send to
- * @param sourceURL a KURL pointing to the file to send
- * @param altFileName an alternate filename describing the file or a
- * description or title
- * @param fileSize file size in bytes
- *
- * @see messageContact()
- * @see chatWithContact()
- * @see isPresent()
- * @see fileTransferContacts()
- * @see KABC::Addressee::uid()
- */
- void sendFile(const TQString &uid, const KURL &sourceURL,
- const TQString &altFileName = TQString::null, uint fileSize = 0);
-
- /**
- * @brief Add a new contact given its protocol specific identifier
- *
- * @param contactId the protocol specific identifier for the contact
- * e.g. UIN for ICQ, screenname for AIM, nick for IRC
- * @param protocol the IM protocol/service to use.
- * See KIMIface:::protocols()
- * @return whether the add succeeded. @c false may signal already present,
- * protocol not supported, or add operation not supported.
- *
- * @see locate()
- * @see KIMIface::protocols()
- */
- bool addContact( const TQString &contactId, const TQString &protocol );
-
- /**
- * @brief Checks if there are any compatible instant messaging
- * applications available
- *
- * Available means that they are started and registered with DCOP
- * and implementing the correct DCOP service.
- * This information will be updated on the first call to initialize()
- * and whenever an application registers or unregisters with DCOP,
- * i.e. the information will be kept up to date.
- *
- * @return @c true if there are any apps available
- */
- bool imAppsAvailable();
-
- /**
- * @brief Start the user's preferred IM application
- * @return whether a preferred app was found. No guarantee that it
- * started correctly
- */
- bool startPreferredApp();
-
- /**
- * Just exists to let the IDL compiler make the DCOP signal for this
- */
- void contactPresenceChanged( TQString uid, TQCString appId, int presence );
-
- public slots:
- /**
- * @brief Updates the proxy's data after a new application registered
- * with DCOP
- *
- * Checks if the application specified by the given DCOP application
- * identifier implements the instant messenger service.
- *
- * @param appId the DCOP application ID of the newly registered
- * application
- *
- * @see DCOPClient::applicationRegistered()
- */
- void registeredToDCOP( const TQCString& appId );
-
- /**
- * @brief Updates the proxy's data after an application unregistered
- * with DCOP
- *
- * If the application specified by the given DCOP application
- * identifier is one of the instant messenger applications of the
- * proxy, it will remove the presence information it gathered from it
- * earlier on.
- *
- * Emits sigPresenceInfoExpired() to let the using applcation know
- * its presence related information might need updating.
- *
- * @param appId the DCOP application ID of the now unregistered
- * application
- *
- * @see DCOPClient::applicationRemoved()
- */
- void unregisteredFromDCOP( const TQCString& appId );
- signals:
- /**
- * @brief Indicates that the specified IM-contact's presence changed
- *
- * @param uid the KABC UID whose presence changed
- *
- * @see isPresent()
- * @see presenceNumeric()
- * @see presenceIcon()
- * @see KABC::Addressee::uid()
- */
- void sigContactPresenceChanged( const TQString &uid );
-
- /**
- * @brief Indicates that presence information obtained earlier on might
- * not be valid any longer
- *
- * After the sources of presence information have changed so any
- * previously supplied presence info is invalid.
- */
- void sigPresenceInfoExpired();
- protected:
- /**
- * Bootstrap our presence data for a newly registered app
- */
- void pollApp( const TQCString & appId );
- /**
- * Bootstrap our presence data by polling all known apps
- */
- void pollAll( const TQString &uid );
-
- /**
- * Update our records with the given data
- */
- bool updatePresence( const TQString &uid, const TQCString &appId, int presence );
-
- /**
- * Get the name of the user's IM application of choice
- */
- TQString preferredApp();
-
- /**
- * Get the app stub best able to reach this uid
- */
- KIMIface_stub * stubForUid( const TQString &uid );
-
- /**
- * Get the app stub for this protocol.
- * Take the preferred app first, then any other.
- */
- KIMIface_stub * stubForProtocol( const TQString &protocol );
-
- private:
- // client stubs used to get presence
- // appId (from DCOP) -> KIMIface_stub
- TQDict<KIMIface_stub> m_im_client_stubs;
- // map containing numeric presence and the originating application ID for each KABC uid we know of
- // KABC Uid -> (appId, numeric presence )(AppPresence)
- PresenceMap m_presence_map;
- // cache of the client strings in use by each application
- // dictionary of KIMIface_stub -> map of numeric presence -> string presence
- // FIXME: remove for KDE4 - UNUSED but maintained for binary compatibility in KDE 3.4
- TQPtrDict<int> m_client_presence_strings;
- Private * d;
- bool m_apps_available;
- bool m_initialized;
- /**
- * Construct an instance of the proxy library.
- */
- KIMProxy( DCOPClient * client);
- static KIMProxy * s_instance;
-};
-
-#endif
-
diff --git a/interfaces/kimproxy/library/kimproxyiface.h b/interfaces/kimproxy/library/kimproxyiface.h
deleted file mode 100644
index fa11183c9..000000000
--- a/interfaces/kimproxy/library/kimproxyiface.h
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- kimproxyiface.cpp
-
- IM service library for KDE
-
- DCOP interface to allow us to receive DCOP signals
-
- Copyright (c) 2004 Will Stephenson <[email protected]>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library 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
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#ifndef KIMPROXYIFACE_H
-#define KIMPROXYIFACE_H
-
-#include <dcopobject.h>
-
-class KIMProxyIface : virtual public DCOPObject
-{
- K_DCOP
- k_dcop:
- virtual void contactPresenceChanged( TQString uid, TQCString appId, int presence ) = 0;
-};
-
-#endif