summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--Android.mk14
-rw-r--r--screen_source/Android.mk31
-rw-r--r--screen_source/aml_screen.cpp296
-rw-r--r--screen_source/v4l2_vdin.cpp676
-rw-r--r--screen_source/v4l2_vdin.h144
-rw-r--r--tv_callback.h18
-rw-r--r--tv_input.cpp263
-rw-r--r--tvapi/android/Android.mk2
-rw-r--r--tvapi/android/include/ITv.h98
-rw-r--r--tvapi/android/include/ITvClient.h56
-rw-r--r--tvapi/android/include/ITvService.h66
-rw-r--r--tvapi/android/include/Tv.h158
-rw-r--r--tvapi/android/include/tvcmd.h1212
-rw-r--r--tvapi/android/jni/Android.mk135
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp18
-rw-r--r--tvapi/android/jni/cfbc_test.cpp86
-rw-r--r--tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp (renamed from tvapi/android/jni/android_amlogic_tv.cpp)929
-rw-r--r--tvapi/android/libtvbinder/Android.mk48
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp292
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp116
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp100
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp378
-rw-r--r--tvapi/android/tv/Android.mk23
-rw-r--r--tvapi/android/tv/CTv.cpp104
-rw-r--r--tvapi/android/tv/CTv.h54
-rw-r--r--tvapi/android/tvserver/Android.mk164
-rw-r--r--tvapi/android/tvserver/TvService.cpp8911
-rw-r--r--tvapi/android/tvserver/TvService.h170
-rw-r--r--tvapi/android/tvserver/main.cpp46
-rw-r--r--tvapi/android/tvserver/tv_callback.h18
-rw-r--r--[-rwxr-xr-x]tvapi/build/include/.gitignore0
-rw-r--r--tvapi/build/include/xxxconfig.h1
-rw-r--r--tvapi/docs/tv.uml12156
-rw-r--r--tvapi/libtv/Android.mk12
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.cpp126
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.h31
-rw-r--r--tvapi/libtv/audio/CTvAudio.cpp30
-rw-r--r--tvapi/libtv/audio/CTvAudio.h76
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp2073
-rw-r--r--tvapi/libtv/audio/audio_alsa.h257
-rw-r--r--tvapi/libtv/audio/audio_android.cpp1035
-rw-r--r--tvapi/libtv/audio/audio_android.h78
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp591
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h65
-rw-r--r--tvapi/libtv/audio/audio_api.cpp2470
-rw-r--r--tvapi/libtv/audio/audio_api.h323
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp356
-rw-r--r--tvapi/libtv/audio/audio_effect.h58
-rw-r--r--tvapi/libtv/include/amstream.h526
-rw-r--r--tvapi/libtv/include/amvecm.h136
-rw-r--r--tvapi/libtv/include/cm.h308
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h316
-rw-r--r--tvapi/libtv/include/ve.h461
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp425
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.cpp150
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.h41
-rw-r--r--tvapi/libtv/tv/CAv.cpp116
-rw-r--r--tvapi/libtv/tv/CAv.h24
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp443
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h25
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp198
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h19
-rw-r--r--tvapi/libtv/tv/CTv.cpp13003
-rw-r--r--tvapi/libtv/tv/CTv.h1453
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp324
-rw-r--r--tvapi/libtv/tv/CTvBooking.h166
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp24
-rw-r--r--tvapi/libtv/tv/CTvEv.h12
-rw-r--r--tvapi/libtv/tv/CTvLog.h8
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp552
-rw-r--r--tvapi/libtv/tv/CTvRecord.h92
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h42
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp335
-rw-r--r--tvapi/libtv/tv/CTvScanner.h26
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1279
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h351
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp361
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h484
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp6
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp4
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h282
-rw-r--r--tvapi/libtv/tv/ScreenCatch.cpp379
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp706
-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.h574
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp25
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h188
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp86
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h194
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp483
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h170
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp88
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h60
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1806
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h1066
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp366
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h84
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp38
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp478
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.h73
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp203
-rw-r--r--tvapi/libtv/tvin/CTvin.h191
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp54
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h100
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp403
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h152
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp160
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h52
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp258
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h74
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp4658
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.h30
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h782
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp10
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp2726
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.h64
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp2575
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h239
-rw-r--r--tvapi/libtv/tvutils/CCondition.h2
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp65
-rw-r--r--tvapi/libtv/tvutils/CFile.h3
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp2
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp31
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h3
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h96
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp18
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp8
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h12
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp2
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp25
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h4
-rw-r--r--tvapi/libtv/tvutils/serial_base.h34
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp66
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h70
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp3931
-rw-r--r--tvapi/libtv/tvutils/tvutils.h222
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp2
-rw-r--r--tvapi/libtv/version/version.cpp188
-rw-r--r--tvapi/libtv/version/version.h22
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp3509
-rw-r--r--tvapi/libtv/vpp/CPQdb.h340
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp5602
-rw-r--r--tvapi/libtv/vpp/CVpp.h230
-rw-r--r--tvapi/tvtests/Android.mk98
-rw-r--r--tvapi/tvtests/android_tvtest.cpp2
-rw-r--r--tvapi/tvtests/comm_test.cpp4
-rw-r--r--tvapi/tvtests/ssm_test.cpp420
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp854
151 files changed, 45277 insertions, 47437 deletions
diff --git a/tvapi/libtv/tvdb/CTvEvent.cpp b/tvapi/libtv/tvdb/CTvEvent.cpp
index 12f8352..b660fc9 100644
--- a/tvapi/libtv/tvdb/CTvEvent.cpp
+++ b/tvapi/libtv/tvdb/CTvEvent.cpp
@@ -1,241 +1,242 @@
-//
-//
-// amlogic 2013
-//
-// @ Project : tv
-// @ File Name : CTvEvent.cpp
-// @ Date : 2013-11
-// @ Author :
-//
-//
-
-#include "CTvEvent.h"
-#include "CTvDatabase.h"
-#include "CTvProgram.h"
-#include <stdlib.h>
-
-#ifdef LOG_TAG
-#undef LOG_TAG
-#define LOG_TAG "CTvEvent"
-#endif
-
-void CTvEvent::InitFromCursor(CTvDatabase::Cursor &c)
-{
- int col;
-
- col = c.getColumnIndex("db_id");
- this->id = c.getInt(col);
-
- col = c.getColumnIndex("event_id");
- this->dvbEventID = c.getInt(col);
-
- col = c.getColumnIndex("name");
- this->name = c.getString(col);
-
- col = c.getColumnIndex("start");
- this->start = (long)c.getInt(col);
-
- col = c.getColumnIndex("end");
- this->end = (long)c.getInt(col) ;
-
- col = c.getColumnIndex("nibble_level");
- this->dvbContent = c.getInt(col);
-
- col = c.getColumnIndex("parental_rating");
- this->dvbViewAge = c.getInt(col);
-
- col = c.getColumnIndex("sub_flag");
- this->sub_flag = c.getInt(col);
-
- col = c.getColumnIndex("db_srv_id");
- this->programID = c.getInt(col);
-
- col = c.getColumnIndex("rrt_ratings");
- String8 rrtRatings = c.getString(col);
- char *tmp;
- Vector<String8> ratings;
- int l = 0;
- tmp = strtok(rrtRatings.lockBuffer(rrtRatings.size()), ",");
- LOGD("%s, %d, %s", "TV", __LINE__, tmp);
- while (tmp != NULL) {
- ratings.push_back(String8(tmp));
- tmp = strtok(NULL, ",");
- }
- rrtRatings.unlockBuffer();
- rating_len = ratings.size();
- if (!ratings.isEmpty()) {
- for (int i = 0; i < ratings.size(); i++) {
- Vector<String8> rating;
- tmp = strtok(ratings.editItemAt(i).lockBuffer(ratings.editItemAt(i).length()), " ");
- while (tmp != NULL) {
- rating.push_back(String8(tmp));
- tmp = strtok(NULL, " ");
- }
- ratings.editItemAt(i).unlockBuffer();
- if (rating.size() >= 3) {
- int re = atoi(rating[0]);
- int dm = atoi(rating[1]);
- int vl = atoi(rating[2]);
- vchipRatings.add( new CTvDimension::VChipRating(re, dm, vl));
- } else
- vchipRatings.add(NULL);
- }
- }
-
- col = c.getColumnIndex("descr");
- this->description = c.getString(col);
-
- col = c.getColumnIndex("ext_descr");
- this->extDescription = c.getString(col);
-}
-
-//id; CTvChannel.MODE_ATSC sourceid , other id
-int CTvEvent::getProgPresentEvent(int progSrc, int progID, long nowTime, CTvEvent &ev)
-{
- String8 cmd;
- CTvDatabase::Cursor c;
-
- cmd = String8("select * from evt_table where evt_table.");
-
- if (progSrc == CTvChannel::MODE_ATSC) {
- cmd += String8("source_id = ") + String8::format("%d", progID);
- } else {
- cmd += String8("db_srv_id = ") + String8::format("%d", progID);
- }
-
- cmd += String8(" and evt_table.start <= ") + String8::format("%ld", nowTime) + String8(" and evt_table.end > ") + String8::format("%ld", nowTime);
-
- int ret = CTvDatabase::GetTvDb()->select(cmd, c);
-
- if(c.moveToFirst()) {
- ev.InitFromCursor(c);
- } else {
- c.close();
- return -1;
- }
-
- c.close();
-
- return 0;
-}
-
-int CTvEvent::getProgScheduleEvents(int progSrc, int progID, long start, long duration, Vector<sp<CTvEvent> > &vEv)
-{
- String8 cmd;
- long begin = start;
- long end = start + duration;
-
- cmd = String8("select * from evt_table where evt_table.");
- if (progSrc == CTvChannel::MODE_ATSC) {
- cmd += String8("source_id = ") + String8::format("%d", progID);
- } else {
- cmd += String8("db_srv_id = ") + String8::format("%d", progID);
- }
- cmd += String8(" and ");
- cmd += String8(" ((start < ") + String8::format("%ld", begin) + String8(" and end > ") + String8::format("%ld", begin) + String8(") ||");
- cmd += String8(" (start >= ") + String8::format("%ld", begin) + String8(" and start < ") + String8::format("%ld", end) + String8("))");
- cmd += String8(" order by evt_table.start");
-
- CTvDatabase::Cursor c;
- int ret = CTvDatabase::GetTvDb()->select(cmd, c);
-
- if(c.moveToFirst()) {
- do {
- vEv.add(new CTvEvent(c));
- } while(c.moveToNext());
-
- } else {
- c.close();
- return -1;
- }
-
- c.close();
- return 0;
-}
-int CTvEvent::getATVProgEvent(int progSrc, int progID, CTvEvent &ev)
-{
- String8 cmd;
- CTvDatabase::Cursor c;
-
- cmd = String8("select * from evt_table where evt_table.");
-
- if (progSrc == CTvChannel::MODE_ATSC) {
- LOGD("%s, %d MODE_ATSC", "TV", __LINE__);
- cmd += String8("source_id = ") + String8::format("%d", progID);
- } else {
- LOGD("%s, %d MODE_ANALOG", "TV", __LINE__);
- cmd += String8("db_srv_id = ") + String8::format("%d", progID);
- }
-
- //cmd += String8(" and evt_table.start <= ") + String8::format("%ld", nowTime) + String8(" and evt_table.end > ") + String8::format("%ld", nowTime);
-
- int ret = CTvDatabase::GetTvDb()->select(cmd, c);
-
- if(c.moveToFirst()) {
- ev.InitFromCursor(c);
- } else {
- c.close();
- return -1;
- }
-
- c.close();
-
- return 0;
-}
-
-int CTvEvent::CleanAllEvent()
-{
- CTvDatabase::GetTvDb()->exeSql("delete from evt_table");
- return 0;
-}
-
-int CTvEvent::selectByID(int id, CTvEvent &evt)
-{
- CTvDatabase::Cursor c;
- String8 sql;
-
- sql = String8("select * from evt_table where evt_table.db_id = ") + String8::format("%d", id);
- CTvDatabase::GetTvDb()->select(sql.string(), c);
- if(c.moveToFirst()) {
- evt.InitFromCursor(c);
- } else {
- c.close();
- return -1;
- }
-
- c.close();
- return 0;
-}
-
-int CTvEvent::bookEvent(int evtId, bool bBookFlag)
-{
- String8 cmd;
-
- cmd = String8("update evt_table set sub_flag=") + String8::format("%d", bBookFlag)
- + String8(" where event_id=") + String8::format("%d", evtId);
-
- CTvDatabase::GetTvDb()->exeSql(cmd.string());
-
- return 0;
-}
-
-CTvEvent::CTvEvent(CTvDatabase::Cursor &c)
-{
- InitFromCursor(c);
-}
-
-CTvEvent::CTvEvent()
-{
-}
-
-CTvEvent::~CTvEvent()
-{
- int size = vchipRatings.size();
- for (int i = 0; i < size; i++)
- delete vchipRatings[i];
-}
-Vector<CTvDimension::VChipRating *> CTvEvent::getVChipRatings()
-{
- return vchipRatings;
-}
-
+//
+//
+// amlogic 2013
+//
+// @ Project : tv
+// @ File Name : CTvEvent.cpp
+// @ Date : 2013-11
+// @ Author :
+//
+//
+
+#include "CTvEvent.h"
+#include "CTvDatabase.h"
+#include "CTvProgram.h"
+#include <stdlib.h>
+
+#ifdef LOG_TAG
+#undef LOG_TAG
+#define LOG_TAG "CTvEvent"
+#endif
+
+void CTvEvent::InitFromCursor(CTvDatabase::Cursor &c)
+{
+ int col;
+
+ col = c.getColumnIndex("db_id");
+ this->id = c.getInt(col);
+
+ col = c.getColumnIndex("event_id");
+ this->dvbEventID = c.getInt(col);
+
+ col = c.getColumnIndex("name");
+ this->name = c.getString(col);
+
+ col = c.getColumnIndex("start");
+ this->start = (long)c.getInt(col);
+
+ col = c.getColumnIndex("end");
+ this->end = (long)c.getInt(col) ;
+
+ col = c.getColumnIndex("nibble_level");
+ this->dvbContent = c.getInt(col);
+
+ col = c.getColumnIndex("parental_rating");
+ this->dvbViewAge = c.getInt(col);
+
+ col = c.getColumnIndex("sub_flag");
+ this->sub_flag = c.getInt(col);
+
+ col = c.getColumnIndex("db_srv_id");
+ this->programID = c.getInt(col);
+
+ col = c.getColumnIndex("rrt_ratings");
+ String8 rrtRatings = c.getString(col);
+ char *tmp;
+ Vector<String8> ratings;
+ int l = 0;
+ char *pSave;
+ tmp = strtok_r(rrtRatings.lockBuffer(rrtRatings.size()), ",", &pSave);
+ LOGD("%s, %d, %s", "TV", __LINE__, tmp);
+ while (tmp != NULL) {
+ ratings.push_back(String8(tmp));
+ tmp = strtok_r(NULL, ",", &pSave);
+ }
+ rrtRatings.unlockBuffer();
+ rating_len = ratings.size();
+ if (!ratings.isEmpty()) {
+ for (int i = 0; i < ratings.size(); i++) {
+ Vector<String8> rating;
+ tmp = strtok_r(ratings.editItemAt(i).lockBuffer(ratings.editItemAt(i).length()), " ", &pSave);
+ while (tmp != NULL) {
+ rating.push_back(String8(tmp));
+ tmp = strtok_r(NULL, " ", &pSave);
+ }
+ ratings.editItemAt(i).unlockBuffer();
+ if (rating.size() >= 3) {
+ int re = atoi(rating[0]);
+ int dm = atoi(rating[1]);
+ int vl = atoi(rating[2]);
+ vchipRatings.add( new CTvDimension::VChipRating(re, dm, vl));
+ } else
+ vchipRatings.add(NULL);
+ }
+ }
+
+ col = c.getColumnIndex("descr");
+ this->description = c.getString(col);
+
+ col = c.getColumnIndex("ext_descr");
+ this->extDescription = c.getString(col);
+}
+
+//id; CTvChannel.MODE_ATSC sourceid , other id
+int CTvEvent::getProgPresentEvent(int progSrc, int progID, long nowTime, CTvEvent &ev)
+{
+ String8 cmd;
+ CTvDatabase::Cursor c;
+
+ cmd = String8("select * from evt_table where evt_table.");
+
+ if (progSrc == CTvChannel::MODE_ATSC) {
+ cmd += String8("source_id = ") + String8::format("%d", progID);
+ } else {
+ cmd += String8("db_srv_id = ") + String8::format("%d", progID);
+ }
+
+ cmd += String8(" and evt_table.start <= ") + String8::format("%ld", nowTime) + String8(" and evt_table.end > ") + String8::format("%ld", nowTime);
+
+ int ret = CTvDatabase::GetTvDb()->select(cmd, c);
+
+ if (c.moveToFirst()) {
+ ev.InitFromCursor(c);
+ } else {
+ c.close();
+ return -1;
+ }
+
+ c.close();
+
+ return 0;
+}
+
+int CTvEvent::getProgScheduleEvents(int progSrc, int progID, long start, long duration, Vector<sp<CTvEvent> > &vEv)
+{
+ String8 cmd;
+ long begin = start;
+ long end = start + duration;
+
+ cmd = String8("select * from evt_table where evt_table.");
+ if (progSrc == CTvChannel::MODE_ATSC) {
+ cmd += String8("source_id = ") + String8::format("%d", progID);
+ } else {
+ cmd += String8("db_srv_id = ") + String8::format("%d", progID);
+ }
+ cmd += String8(" and ");
+ cmd += String8(" ((start < ") + String8::format("%ld", begin) + String8(" and end > ") + String8::format("%ld", begin) + String8(") ||");
+ cmd += String8(" (start >= ") + String8::format("%ld", begin) + String8(" and start < ") + String8::format("%ld", end) + String8("))");
+ cmd += String8(" order by evt_table.start");
+
+ CTvDatabase::Cursor c;
+ int ret = CTvDatabase::GetTvDb()->select(cmd, c);
+
+ if (c.moveToFirst()) {
+ do {
+ vEv.add(new CTvEvent(c));
+ } while (c.moveToNext());
+
+ } else {
+ c.close();
+ return -1;
+ }
+
+ c.close();
+ return 0;
+}
+int CTvEvent::getATVProgEvent(int progSrc, int progID, CTvEvent &ev)
+{
+ String8 cmd;
+ CTvDatabase::Cursor c;
+
+ cmd = String8("select * from evt_table where evt_table.");
+
+ if (progSrc == CTvChannel::MODE_ATSC) {
+ LOGD("%s, %d MODE_ATSC", "TV", __LINE__);
+ cmd += String8("source_id = ") + String8::format("%d", progID);
+ } else {
+ LOGD("%s, %d MODE_ANALOG", "TV", __LINE__);
+ cmd += String8("db_srv_id = ") + String8::format("%d", progID);
+ }
+
+ //cmd += String8(" and evt_table.start <= ") + String8::format("%ld", nowTime) + String8(" and evt_table.end > ") + String8::format("%ld", nowTime);
+
+ int ret = CTvDatabase::GetTvDb()->select(cmd, c);
+
+ if (c.moveToFirst()) {
+ ev.InitFromCursor(c);
+ } else {
+ c.close();
+ return -1;
+ }
+
+ c.close();
+
+ return 0;
+}
+
+int CTvEvent::CleanAllEvent()
+{
+ CTvDatabase::GetTvDb()->exeSql("delete from evt_table");
+ return 0;
+}
+
+int CTvEvent::selectByID(int id, CTvEvent &evt)
+{
+ CTvDatabase::Cursor c;
+ String8 sql;
+
+ sql = String8("select * from evt_table where evt_table.db_id = ") + String8::format("%d", id);
+ CTvDatabase::GetTvDb()->select(sql.string(), c);
+ if (c.moveToFirst()) {
+ evt.InitFromCursor(c);
+ } else {
+ c.close();
+ return -1;
+ }
+
+ c.close();
+ return 0;
+}
+
+int CTvEvent::bookEvent(int evtId, bool bBookFlag)
+{
+ String8 cmd;
+
+ cmd = String8("update evt_table set sub_flag=") + String8::format("%d", bBookFlag)
+ + String8(" where event_id=") + String8::format("%d", evtId);
+
+ CTvDatabase::GetTvDb()->exeSql(cmd.string());
+
+ return 0;
+}
+
+CTvEvent::CTvEvent(CTvDatabase::Cursor &c)
+{
+ InitFromCursor(c);
+}
+
+CTvEvent::CTvEvent()
+{
+}
+
+CTvEvent::~CTvEvent()
+{
+ int size = vchipRatings.size();
+ for (int i = 0; i < size; i++)
+ delete vchipRatings[i];
+}
+Vector<CTvDimension::VChipRating *> CTvEvent::getVChipRatings()
+{
+ return vchipRatings;
+}
+