summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--tv_input.cpp45
-rw-r--r--tvapi/android/Android.mk2
-rw-r--r--tvapi/android/include/ITv.h100
-rw-r--r--tvapi/android/include/ITvClient.h58
-rw-r--r--tvapi/android/include/ITvService.h68
-rw-r--r--tvapi/android/include/Tv.h161
-rw-r--r--tvapi/android/include/tvcmd.h1188
-rw-r--r--tvapi/android/jni/Android.mk132
-rw-r--r--tvapi/android/jni/android_amlogic_tv.cpp911
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp214
-rw-r--r--tvapi/android/jni/cfbc_test.cpp86
-rw-r--r--tvapi/android/libtvbinder/Android.mk48
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp289
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp117
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp101
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp378
-rw-r--r--tvapi/android/tvserver/Android.mk162
-rw-r--r--tvapi/android/tvserver/TvService.cpp8755
-rw-r--r--tvapi/android/tvserver/TvService.h164
-rw-r--r--tvapi/android/tvserver/main.cpp46
-rwxr-xr-x[-rw-r--r--]tvapi/build/include/.gitignore0
-rw-r--r--tvapi/docs/tv.uml12156
-rw-r--r--tvapi/libtv/Android.mk3
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp2426
-rw-r--r--tvapi/libtv/audio/audio_alsa.h261
-rw-r--r--tvapi/libtv/audio/audio_android.cpp2070
-rw-r--r--tvapi/libtv/audio/audio_android.h157
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp1182
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h131
-rw-r--r--tvapi/libtv/audio/audio_api.cpp4940
-rw-r--r--tvapi/libtv/audio/audio_api.h647
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp456
-rw-r--r--tvapi/libtv/audio/audio_effect.h63
-rw-r--r--tvapi/libtv/include/amstream.h526
-rw-r--r--tvapi/libtv/include/amvecm.h136
-rw-r--r--tvapi/libtv/include/cm.h306
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h508
-rw-r--r--tvapi/libtv/include/ve.h438
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp426
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h47
-rw-r--r--tvapi/libtv/tv/CAv.cpp484
-rw-r--r--tvapi/libtv/tv/CAv.h194
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp2326
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h680
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp838
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h227
-rw-r--r--tvapi/libtv/tv/CTv.cpp10755
-rw-r--r--tvapi/libtv/tv/CTv.h1269
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp324
-rw-r--r--tvapi/libtv/tv/CTvBooking.h167
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp8
-rw-r--r--tvapi/libtv/tv/CTvDmx.h15
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp260
-rw-r--r--tvapi/libtv/tv/CTvEpg.h280
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp2
-rw-r--r--tvapi/libtv/tv/CTvEv.h314
-rw-r--r--tvapi/libtv/tv/CTvLog.h8
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp552
-rw-r--r--tvapi/libtv/tv/CTvRecord.h93
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h43
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1417
-rw-r--r--tvapi/libtv/tv/CTvScanner.h319
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1060
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h351
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp272
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h469
-rw-r--r--tvapi/libtv/tv/CTvTime.h137
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp250
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h43
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp974
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h284
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp706
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h79
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.conf58
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp106
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.h40
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp694
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h575
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp300
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h190
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp714
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h196
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp482
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h171
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp88
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h61
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1766
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h1065
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp366
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h85
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp830
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp448
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp4240
-rw-r--r--tvapi/libtv/tvin/CTvin.h2222
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp54
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h101
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp706
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h153
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp160
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h53
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp258
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h75
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp4424
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h742
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp38
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h11
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp2784
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp3706
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h338
-rw-r--r--tvapi/libtv/tvutils/CCondition.h87
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp250
-rw-r--r--tvapi/libtv/tvutils/CFile.h53
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp6
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h9
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp144
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h44
-rw-r--r--tvapi/libtv/tvutils/CMutex.h116
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp118
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h98
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp568
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h45
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h292
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp212
-rw-r--r--tvapi/libtv/tvutils/CThread.h79
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp196
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h49
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp560
-rw-r--r--tvapi/libtv/tvutils/serial_base.h34
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp336
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h72
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp3822
-rw-r--r--tvapi/libtv/tvutils/tvutils.h238
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp66
-rw-r--r--tvapi/libtv/tvutils/zepoll.h57
-rw-r--r--tvapi/libtv/version/version.cpp188
-rw-r--r--tvapi/libtv/version/version.h22
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp3183
-rw-r--r--tvapi/libtv/vpp/CPQdb.h321
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp4772
-rw-r--r--tvapi/libtv/vpp/CVpp.h683
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp216
-rw-r--r--tvapi/tvtests/Android.mk98
-rw-r--r--tvapi/tvtests/android_tvtest.cpp30
-rw-r--r--tvapi/tvtests/comm_test.cpp42
-rw-r--r--tvapi/tvtests/ssm_test.cpp420
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp854
147 files changed, 55964 insertions, 55946 deletions
diff --git a/tvapi/libtv/tvdb/CTvChannel.cpp b/tvapi/libtv/tvdb/CTvChannel.cpp
index d39d025..c01fea6 100644
--- a/tvapi/libtv/tvdb/CTvChannel.cpp
+++ b/tvapi/libtv/tvdb/CTvChannel.cpp
@@ -1,347 +1,347 @@
-//
-//
-// amlogic 2013
-//
-// @ Project : tv
-// @ File Name : CTvChannel.cpp
-// @ Date : 2013-11
-// @ Author :
-//
-//
-
-
-#include "CTvChannel.h"
-
-#ifdef LOG_TAG
-#undef LOG_TAG
-#define LOG_TAG "CTvChannel"
-#endif
-
-void CTvChannel::createFromCursor(CTvDatabase::Cursor &c)
-{
- int col;
- int src, freq, mod, symb, bw, satid, satpolar;
-
- col = c.getColumnIndex("db_id");
- this->id = c.getInt(col);
-
- col = c.getColumnIndex("ts_id");
- this->dvbTSID = c.getInt(col);
-
- col = c.getColumnIndex("src");
- src = c.getInt(col);
-
- col = c.getColumnIndex("freq");
- freq = c.getInt(col);
-
- if (src == MODE_QAM) {
- col = c.getColumnIndex("mod");
- mod = c.getInt(col);
-
- col = c.getColumnIndex("symb");
- symb = c.getInt(col);
-
- frequency = freq;
- modulation = mod;
- symbolRate = symb;
- mode = MODE_QAM;
-
- } else if (src == MODE_OFDM) {
- col = c.getColumnIndex("bw");
- bw = c.getInt(col);
-
- frequency = freq;
- bandwidth = bw;
- mode = MODE_OFDM;
-
- } else if (src == MODE_ATSC) {
- col = c.getColumnIndex("mod");
- mod = c.getInt(col);
-
- frequency = freq;
- modulation = mod;
- mode = MODE_ATSC;
- } else if (src == MODE_ANALOG) {
- col = c.getColumnIndex("std");
- int std = c.getInt(col);
- col = c.getColumnIndex("aud_mode");
- int aud_mode = c.getInt(col);
- col = c.getColumnIndex("flags");
- int afc_flag = c.getInt(col);
-
- frequency = freq;
- audio = aud_mode;
- standard = std;
- afc_data = afc_flag;
- mode = MODE_ANALOG;
- } else if (src == MODE_QPSK) {
- col = c.getColumnIndex("symb");
- symb = c.getInt(col);
-
- col = c.getColumnIndex("db_sat_para_id");
- satid = c.getInt(col);
-
- col = c.getColumnIndex("polar");
- satpolar = c.getInt(col);
-
- frequency = freq;
- symbolRate = symb;
- sat_id = satid;
- sat_polarisation = satpolar;
- mode = MODE_QPSK;
-
- /*new tv_satparams*/
- //showboz
- //TVSatellite sat = TVSatellite.tvSatelliteSelect(sat_id);
- //tv_satparams = sat.getParams();
- } else if (src == MODE_DTMB) {
- col = c.getColumnIndex("bw");
- bw = c.getInt(col);
-
- frequency = freq;
- bandwidth = bw;
- mode = MODE_DTMB;
- }
-
- this->fendID = 0;
-}
-
-
-CTvChannel::CTvChannel()
-{
-
-}
-
-CTvChannel::CTvChannel(int dbID, int mode, int freq, int bw, int mod, int symb, int ofdm, int channelNum)
-{
- //other member not init,just a paras
- if (mode == MODE_QAM) {
- id = dbID;
- frequency = freq;
- modulation = mod;
- symbolRate = symb;
- mode = MODE_QAM;
- } else if (mode == MODE_OFDM) {
- id = dbID;
- frequency = freq;
- bandwidth = bw;
- mode = MODE_OFDM;
- } else if (mode == MODE_ATSC) {
- id = dbID;
- frequency = freq;
- modulation = mod;
- logicalChannelNum = channelNum;
- mod = MODE_ATSC;
- } else if (mode == MODE_ANALOG) {
- id = dbID;
- frequency = freq;
- audio = 0;
- standard = 0;
- afc_data = 0;
- mode = MODE_ANALOG;
- } else if (mode == MODE_DTMB) {
- id = dbID;
- frequency = freq;
- bandwidth = bw;
- mode = MODE_DTMB;
- }
-}
-
-CTvChannel::~CTvChannel()
-{
-
-}
-
-Vector<CTvChannel> CTvChannel::tvChannelList(int sat_id)
-{
- Vector<CTvChannel> v_channel;
- return v_channel;
-}
-
-int CTvChannel::selectByID(int cid, CTvChannel &channel)
-{
- String8 cmd = String8("select * from ts_table where ts_table.db_id = ") + String8::format("%d", cid);
- CTvDatabase::Cursor c;
- CTvDatabase::GetTvDb()->select(cmd, c);
-
- if (c.moveToFirst()) {
- channel.createFromCursor(c);
- } else {
- c.close();
- return -1;
- }
- c.close();
-
- return 0;
-}
-
-int CTvChannel::SelectByFreq(int freq, CTvChannel &channel)
-{
- String8 cmd ;
- CTvDatabase::Cursor c;
- int iOutRet = 0;
-
- do {
- cmd = String8("select * from ts_table where ts_table.freq = ") + String8::format("%d", freq);
- CTvDatabase::GetTvDb()->select(cmd, c);
-
- if (c.moveToFirst()) {
- channel.createFromCursor(c);
- } else {
- iOutRet = -1;
- break;
- }
-
- cmd = String8("delete from ts_table where ts_table.freq = ") + String8::format("%d", freq);
- CTvDatabase::GetTvDb()->exeSql(cmd.string());
- } while (false);
-
- c.close();
- return iOutRet;
-}
-
-int CTvChannel::DeleteBetweenFreq(int beginFreq, int endFreq)
-{
- String8 cmd ;
- CTvDatabase::Cursor c;
- int iOutRet = 0;
- CTvChannel channel;
-
- do {
- cmd = String8("select * from ts_table where ts_table.freq >= ") + String8::format("%d", beginFreq)
- + String8("and ts_table.freq <= ") + String8::format("%d", endFreq);
- CTvDatabase::GetTvDb()->select(cmd, c);
- if (c.moveToFirst()) {
- do {
- channel.createFromCursor(c);
- cmd = String8("delete from ts_table where ts_table.freq = ") + String8::format("%d", channel.frequency);
- CTvDatabase::GetTvDb()->exeSql(cmd.string());
- } while (c.moveToNext());
- } else {
- iOutRet = -1;
- break;
- }
-
- } while (false);
-
- c.close();
- return iOutRet;
-}
-
-int CTvChannel::CleanAllChannelBySrc(int src)
-{
- String8 cmd = String8("delete from ts_table where src = ") + String8::format("%d", src);
- CTvDatabase::GetTvDb()->exeSql(cmd.string());
- return 0;
-}
-
-int CTvChannel::getChannelListBySrc(int src, Vector< sp<CTvChannel> > &v_channel)
-{
- CTvDatabase::Cursor c;
- CTvChannel *channel;
- do {
- String8 cmd = String8("select * from ts_table where src = ") + String8::format("%d", src);
- CTvDatabase::GetTvDb()->select(cmd, c);
- if (c.moveToFirst()) {
- do {
- channel = new CTvChannel();
- channel->createFromCursor(c);
- v_channel.add(channel);
- } while (c.moveToNext());
- } else {
- break;
- }
- } while (false);
-
- return 0;
-}
-int CTvChannel::updateByID(int progID, int std, int freq, int fineFreq)
-{
-
- String8 cmd = String8("update ts_table set std = ") + String8::format("%d", std) +
- String8(", freq = ") + String8::format("%d", freq) +
- String8(", flags = ") + String8::format("%d", fineFreq) +
- String8(" where ts_table.db_id = ") + String8::format("%d", progID);
- LOGD("%s, cmd = %s\n", "TV", cmd.string());
- CTvDatabase::GetTvDb()->exeSql(cmd.string());
-
- return 0;
-}
-
-
-void CTvChannel::tvChannelDel()
-{
-
-}
-
-void CTvChannel::tvChannelDelBySatID(int id)
-{
-
-}
-
-int CTvChannel::getDVBTSID()
-{
- return dvbTSID;
-}
-
-void CTvChannel::getDVBOrigNetID()
-{
-
-}
-
-void CTvChannel::getFrontendID()
-{
-
-}
-
-void CTvChannel::getTSSourceID()
-{
-
-}
-
-
-void CTvChannel::isDVBCMode()
-{
-
-}
-
-void CTvChannel::setFrequency()
-{
-
-}
-
-void CTvChannel::setSymbolRate()
-{
-
-}
-
-void CTvChannel::setPolarisation()
-{
-
-}
-
-void CTvChannel::setATVAudio()
-{
-
-}
-
-void CTvChannel::setATVVideoFormat()
-{
-
-}
-
-void CTvChannel::setATVAudioFormat()
-{
-
-}
-
-void CTvChannel::setATVFreq()
-{
-
-}
-
-void CTvChannel::setATVAfcData()
-{
-
-}
-
+//
+//
+// amlogic 2013
+//
+// @ Project : tv
+// @ File Name : CTvChannel.cpp
+// @ Date : 2013-11
+// @ Author :
+//
+//
+
+
+#include "CTvChannel.h"
+
+#ifdef LOG_TAG
+#undef LOG_TAG
+#define LOG_TAG "CTvChannel"
+#endif
+
+void CTvChannel::createFromCursor(CTvDatabase::Cursor &c)
+{
+ int col;
+ int src, freq, mod, symb, bw, satid, satpolar;
+
+ col = c.getColumnIndex("db_id");
+ this->id = c.getInt(col);
+
+ col = c.getColumnIndex("ts_id");
+ this->dvbTSID = c.getInt(col);
+
+ col = c.getColumnIndex("src");
+ src = c.getInt(col);
+
+ col = c.getColumnIndex("freq");
+ freq = c.getInt(col);
+
+ if(src == MODE_QAM) {
+ col = c.getColumnIndex("mod");
+ mod = c.getInt(col);
+
+ col = c.getColumnIndex("symb");
+ symb = c.getInt(col);
+
+ frequency = freq;
+ modulation = mod;
+ symbolRate = symb;
+ mode = MODE_QAM;
+
+ } else if(src == MODE_OFDM) {
+ col = c.getColumnIndex("bw");
+ bw = c.getInt(col);
+
+ frequency = freq;
+ bandwidth = bw;
+ mode = MODE_OFDM;
+
+ } else if(src == MODE_ATSC) {
+ col = c.getColumnIndex("mod");
+ mod = c.getInt(col);
+
+ frequency = freq;
+ modulation = mod;
+ mode = MODE_ATSC;
+ } else if(src == MODE_ANALOG) {
+ col = c.getColumnIndex("std");
+ int std = c.getInt(col);
+ col = c.getColumnIndex("aud_mode");
+ int aud_mode = c.getInt(col);
+ col = c.getColumnIndex("flags");
+ int afc_flag = c.getInt(col);
+
+ frequency = freq;
+ audio = aud_mode;
+ standard = std;
+ afc_data = afc_flag;
+ mode = MODE_ANALOG;
+ } else if(src == MODE_QPSK) {
+ col = c.getColumnIndex("symb");
+ symb = c.getInt(col);
+
+ col = c.getColumnIndex("db_sat_para_id");
+ satid = c.getInt(col);
+
+ col = c.getColumnIndex("polar");
+ satpolar = c.getInt(col);
+
+ frequency = freq;
+ symbolRate = symb;
+ sat_id = satid;
+ sat_polarisation = satpolar;
+ mode = MODE_QPSK;
+
+ /*new tv_satparams*/
+ //showboz
+ //TVSatellite sat = TVSatellite.tvSatelliteSelect(sat_id);
+ //tv_satparams = sat.getParams();
+ } else if(src == MODE_DTMB) {
+ col = c.getColumnIndex("bw");
+ bw = c.getInt(col);
+
+ frequency = freq;
+ bandwidth = bw;
+ mode = MODE_DTMB;
+ }
+
+ this->fendID = 0;
+}
+
+
+CTvChannel::CTvChannel()
+{
+
+}
+
+CTvChannel::CTvChannel(int dbID, int mode, int freq, int bw, int mod, int symb, int ofdm, int channelNum)
+{
+ //other member not init,just a paras
+ if(mode == MODE_QAM) {
+ id = dbID;
+ frequency = freq;
+ modulation = mod;
+ symbolRate = symb;
+ mode = MODE_QAM;
+ } else if(mode == MODE_OFDM) {
+ id = dbID;
+ frequency = freq;
+ bandwidth = bw;
+ mode = MODE_OFDM;
+ } else if(mode == MODE_ATSC) {
+ id = dbID;
+ frequency = freq;
+ modulation = mod;
+ logicalChannelNum = channelNum;
+ mod = MODE_ATSC;
+ } else if(mode == MODE_ANALOG) {
+ id = dbID;
+ frequency = freq;
+ audio = 0;
+ standard = 0;
+ afc_data = 0;
+ mode = MODE_ANALOG;
+ } else if(mode == MODE_DTMB) {
+ id = dbID;
+ frequency = freq;
+ bandwidth = bw;
+ mode = MODE_DTMB;
+ }
+}
+
+CTvChannel::~CTvChannel()
+{
+
+}
+
+Vector<CTvChannel> CTvChannel::tvChannelList(int sat_id)
+{
+ Vector<CTvChannel> v_channel;
+ return v_channel;
+}
+
+int CTvChannel::selectByID(int cid, CTvChannel &channel)
+{
+ String8 cmd = String8("select * from ts_table where ts_table.db_id = ") + String8::format("%d", cid);
+ CTvDatabase::Cursor c;
+ CTvDatabase::GetTvDb()->select(cmd, c);
+
+ if(c.moveToFirst()) {
+ channel.createFromCursor(c);
+ } else {
+ c.close();
+ return -1;
+ }
+ c.close();
+
+ return 0;
+}
+
+int CTvChannel::SelectByFreq(int freq, CTvChannel &channel)
+{
+ String8 cmd ;
+ CTvDatabase::Cursor c;
+ int iOutRet = 0;
+
+ do {
+ cmd = String8("select * from ts_table where ts_table.freq = ") + String8::format("%d", freq);
+ CTvDatabase::GetTvDb()->select(cmd, c);
+
+ if(c.moveToFirst()) {
+ channel.createFromCursor(c);
+ } else {
+ iOutRet = -1;
+ break;
+ }
+
+ cmd = String8("delete from ts_table where ts_table.freq = ") + String8::format("%d", freq);
+ CTvDatabase::GetTvDb()->exeSql(cmd.string());
+ } while(false);
+
+ c.close();
+ return iOutRet;
+}
+
+int CTvChannel::DeleteBetweenFreq(int beginFreq, int endFreq)
+{
+ String8 cmd ;
+ CTvDatabase::Cursor c;
+ int iOutRet = 0;
+ CTvChannel channel;
+
+ do {
+ cmd = String8("select * from ts_table where ts_table.freq >= ") + String8::format("%d", beginFreq)
+ + String8("and ts_table.freq <= ") + String8::format("%d", endFreq);
+ CTvDatabase::GetTvDb()->select(cmd, c);
+ if (c.moveToFirst()) {
+ do {
+ channel.createFromCursor(c);
+ cmd = String8("delete from ts_table where ts_table.freq = ") + String8::format("%d", channel.frequency);
+ CTvDatabase::GetTvDb()->exeSql(cmd.string());
+ } while(c.moveToNext());
+ } else {
+ iOutRet = -1;
+ break;
+ }
+
+ } while(false);
+
+ c.close();
+ return iOutRet;
+}
+
+int CTvChannel::CleanAllChannelBySrc(int src)
+{
+ String8 cmd = String8("delete from ts_table where src = ") + String8::format("%d", src);
+ CTvDatabase::GetTvDb()->exeSql(cmd.string());
+ return 0;
+}
+
+int CTvChannel::getChannelListBySrc(int src, Vector< sp<CTvChannel> > &v_channel)
+{
+ CTvDatabase::Cursor c;
+ CTvChannel *channel;
+ do {
+ String8 cmd = String8("select * from ts_table where src = ") + String8::format("%d", src);
+ CTvDatabase::GetTvDb()->select(cmd, c);
+ if (c.moveToFirst()) {
+ do {
+ channel = new CTvChannel();
+ channel->createFromCursor(c);
+ v_channel.add(channel);
+ } while(c.moveToNext());
+ } else {
+ break;
+ }
+ } while(false);
+
+ return 0;
+}
+int CTvChannel::updateByID(int progID, int std, int freq, int fineFreq)
+{
+
+ String8 cmd = String8("update ts_table set std = ") + String8::format("%d", std) +
+ String8(", freq = ") + String8::format("%d", freq) +
+ String8(", flags = ") + String8::format("%d", fineFreq) +
+ String8(" where ts_table.db_id = ") + String8::format("%d", progID);
+ LOGD("%s, cmd = %s\n", "TV", cmd.string());
+ CTvDatabase::GetTvDb()->exeSql(cmd.string());
+
+ return 0;
+}
+
+
+void CTvChannel::tvChannelDel()
+{
+
+}
+
+void CTvChannel::tvChannelDelBySatID(int id)
+{
+
+}
+
+int CTvChannel::getDVBTSID()
+{
+ return dvbTSID;
+}
+
+void CTvChannel::getDVBOrigNetID()
+{
+
+}
+
+void CTvChannel::getFrontendID()
+{
+
+}
+
+void CTvChannel::getTSSourceID()
+{
+
+}
+
+
+void CTvChannel::isDVBCMode()
+{
+
+}
+
+void CTvChannel::setFrequency()
+{
+
+}
+
+void CTvChannel::setSymbolRate()
+{
+
+}
+
+void CTvChannel::setPolarisation()
+{
+
+}
+
+void CTvChannel::setATVAudio()
+{
+
+}
+
+void CTvChannel::setATVVideoFormat()
+{
+
+}
+
+void CTvChannel::setATVAudioFormat()
+{
+
+}
+
+void CTvChannel::setATVFreq()
+{
+
+}
+
+void CTvChannel::setATVAfcData()
+{
+
+}
+