/[xmltv_parser]/trunk/xmltv_parser/main.cs
ViewVC logotype

Diff of /trunk/xmltv_parser/main.cs

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 142 by william, Thu Mar 14 13:13:46 2013 UTC revision 248 by william, Fri Mar 22 16:41:42 2013 UTC
# Line 1  Line 1 
1  //#define DISABLE_RELEASE_MODE_KLOGLEVEL_DEBUG // when defined will turn off kLogLevel_Debug messages, in release mode  #define DISABLE_RELEASE_MODE_KLOGLEVEL_DEBUG // when defined will turn off kLogLevel_Debug messages, in release mode
2  //#define DISABLE_DEBUG_MODE_KLOGLEVEL_VERBOSE_DEBUG // when defined will turn off kLogLevel_VerboseDebug message, in debug mode  //#define DISABLE_DEBUG_MODE_KLOGLEVEL_VERBOSE_DEBUG // when defined will turn off kLogLevel_VerboseDebug message, in debug mode
3  //#define USE_DYNAMIC_SORTING_FILTERING_CONTROLS // when defined will setup dynamic sorting and filtering controls for XMLTV Data  //#define USE_DYNAMIC_SORTING_FILTERING_CONTROLS // when defined will setup dynamic sorting and filtering controls for XMLTV Data
4  using System;  using System;
# Line 23  namespace xmltv_parser Line 23  namespace xmltv_parser
23    
24      public partial class main : Form      public partial class main : Form
25      {      {
26            const long MAX_LOG_FILESIZE_IN_BYTES = 250000; //250kb max
27            void TruncateLogFile(FileInfo log_file)
28            {
29                if (!log_file.Exists)
30                {
31                    gLog.CreateLog(log_file.FullName, false, LogLevel.kLogLevel_All_NoProgress, new EventHandler<LoggerOnFlushEventArgs>(Log_OnFlush));
32                }
33                else
34                {
35                    if (log_file.Length > MAX_LOG_FILESIZE_IN_BYTES)
36                    {
37                        string match = string.Format("{0}.*", log_file.Name);
38                        var files = Directory.GetFiles(log_file.Directory.FullName, match).ToList();
39                        files.RemoveAt(0);
40                        files.TrimExcess();
41                        int count = files.Count;
42                        if (log_file.Exists)
43                        {
44                            File.Copy(log_file.FullName, string.Format("{0}.{1}", log_file.FullName, count));
45                        }
46                        gLog.CreateLog(log_file.FullName, true, LogLevel.kLogLevel_All_NoProgress, new EventHandler<LoggerOnFlushEventArgs>(Log_OnFlush));
47                    }
48                    else
49                    {
50                        gLog.CreateLog(log_file.FullName, false, LogLevel.kLogLevel_All_NoProgress, new EventHandler<LoggerOnFlushEventArgs>(Log_OnFlush));
51                    }
52                }
53            }
54    
55          public main()          public main()
56          {          {
57              InitializeComponent();              InitializeComponent();
58              ListViewSorter Sorter = new ListViewSorter();              ListViewSorter Sorter = new ListViewSorter();
59              //lstPrograms.ListViewItemSorter = Sorter;              //lstPrograms.ListViewItemSorter = Sorter;
60    
61              string log_path = Application.StartupPath;              string log_path = Application.StartupPath;
62              string log_filename = string.Format("{0}.log", typeof(main).Assembly.GetName().Name);              string log_filename = string.Format("{0}.log", typeof(main).Assembly.GetName().Name);
63              gLog.CreateLog(string.Format(@"{0}\{1}", log_path, log_filename), false, LogLevel.kLogLevel_All_NoProgress, new EventHandler<LoggerOnFlushEventArgs>(Log_OnFlush));              FileInfo log_file = new FileInfo(string.Format(@"{0}\{1}", log_path, log_filename));
64                TruncateLogFile(log_file);            
65  #if DEBUG  #if DEBUG
66              LogLevel gLevel = gLog.LogLevel;              LogLevel gLevel = gLog.LogLevel;
67  #if DISABLE_DEBUG_MODE_KLOGLEVEL_VERBOSE_DEBUG  #if DISABLE_DEBUG_MODE_KLOGLEVEL_VERBOSE_DEBUG
# Line 179  namespace xmltv_parser Line 210  namespace xmltv_parser
210          #endregion          #endregion
211    
212    
213          #region t          #region CreateControls
214            void AutoResizeDataGridView()
215            {
216                //dataGrid.AutoResizeRow(2, DataGridViewAutoSizeRowMode.AllCellsExceptHeader);
217            
218                for (int i = 0; i < dataGrid.ColumnCount; i++)
219                {
220                    dataGrid.Columns[i].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
221                }
222                //for (int i = 0; i < dataGrid.RowCount; i++)
223                //{
224                //    dataGrid.AutoResizeRow(i, DataGridViewAutoSizeRowMode.AllCellsExceptHeader);
225                //}
226            }
227          void CreateControls()          void CreateControls()
228          {          {
229              try              try
# Line 192  namespace xmltv_parser Line 236  namespace xmltv_parser
236                  }                  }
237                  Type data_type;                  Type data_type;
238                  object datasource = XMLTV.CreateBindingSourceFromData(XMLTV.GetPrograms(), out data_type);                  object datasource = XMLTV.CreateBindingSourceFromData(XMLTV.GetPrograms(), out data_type);
239                  CreatControlsFromType(data_type);                  CreatControlsFromType(data_type);                
                 //XMLTV.CreateSorterFromDataSource(ref datasource, "title");  
240                  dataGrid.DataSource = datasource;                  dataGrid.DataSource = datasource;
241                    AutoResizeDataGridView();
242                  flow_datagrid_sort.Enabled = true;                  flow_datagrid_sort.Enabled = true;
243                    btnSort.PerformClick();
244              }              }
245              catch (Exception ex) { gLog.Error.WriteLine(ex.ToString()); }              catch (Exception ex) { gLog.Error.WriteLine(ex.ToString()); }
246          }          }
# Line 206  namespace xmltv_parser Line 251  namespace xmltv_parser
251  #if USE_DYNAMIC_SORTING_FILTERING_CONTROLS  #if USE_DYNAMIC_SORTING_FILTERING_CONTROLS
252                _CreatControlsFromType(data_type);                _CreatControlsFromType(data_type);
253  #else  #else
254              gLog.Warn.WriteLine("Dynamic creation of sorting and filtering controls has not been enabled.");              gLog.Verbose.Warn.WriteLine("Dynamic creation of sorting and filtering controls has not been enabled.");
255              gLog.Warn.WriteLine("To enable: #define USE_DYNAMIC_SORTING_FILTERING_CONTROLS");              gLog.Verbose.Warn.WriteLine("To enable: #define USE_DYNAMIC_SORTING_FILTERING_CONTROLS");
256  #endif  #endif
257          }          }
258          [Conditional("USE_DYNAMIC_SORTING_FILTERING_CONTROLS")]          [Conditional("USE_DYNAMIC_SORTING_FILTERING_CONTROLS")]
# Line 226  namespace xmltv_parser Line 271  namespace xmltv_parser
271          void CreateDefaultControls(Type data_type)          void CreateDefaultControls(Type data_type)
272          {          {
273              // no default controls              // no default controls
274              gLog.Warn.WriteLine("No controls have been defined for: {0}", data_type.Name);              gLog.Verbose.Warn.WriteLine("No controls have been defined for: {0}", data_type.Name);
275          }          }
276          [Conditional("USE_DYNAMIC_SORTING_FILTERING_CONTROLS")]          [Conditional("USE_DYNAMIC_SORTING_FILTERING_CONTROLS")]
277          void CreateSourceDefinitionControls(Type data_type)          void CreateSourceDefinitionControls(Type data_type)
278          {          {
279              // no controls needed              // no controls needed
280              gLog.Warn.WriteLine("No controls have been defined for: {0}", data_type.Name);              gLog.Verbose.Warn.WriteLine("No controls have been defined for: {0}", data_type.Name);
281          }          }
282          [Conditional("USE_DYNAMIC_SORTING_FILTERING_CONTROLS")]          [Conditional("USE_DYNAMIC_SORTING_FILTERING_CONTROLS")]
283          void CreateChannelDefinitionControls(Type data_type)          void CreateChannelDefinitionControls(Type data_type)
284          {          {
285              gLog.Warn.WriteLine("No controls have been defined for: {0}", data_type.Name);              gLog.Verbose.Warn.WriteLine("No controls have been defined for: {0}", data_type.Name);
286          }          }
287          [Conditional("USE_DYNAMIC_SORTING_FILTERING_CONTROLS")]          [Conditional("USE_DYNAMIC_SORTING_FILTERING_CONTROLS")]
288          void CreateProgramDefinitionControls(Type data_type)          void CreateProgramDefinitionControls(Type data_type)
289          {          {
290              gLog.Warn.WriteLine("No controls have been defined for: {0}", data_type.Name);              gLog.Verbose.Warn.WriteLine("No controls have been defined for: {0}", data_type.Name);
291          }          }
292          #endregion          #endregion
293    
294            #region Program Entry Display        
295          #region Column Sorting Support          private int CurrentRowIndex = -1;
296          private bool Descending = false;          void DisplaySelectedProgramEntry(DataGridViewRow row)
         private void ToggleDescedning() { Descending = Descending ? false : true; }  
         private void btnResetSort_Click(object sender, EventArgs e)  
297          {          {
298              Type data_type;              int RowIndex = row.Index; // this is the index in the list
             object datasource = XMLTV.CreateBindingSourceFromData(XMLTV.GetPrograms(), out data_type);  
             dataGrid.DataSource = datasource;  
             ToggleDescedning();  
         }  
299    
300          private void SortByColumn(Button button)              //if (CurrentRowIndex == -1) { AlreadyDisplayedProgramEntryForIndex = false; CurrentRowIndex = RowIndex; }
301          {              //if (CurrentRowIndex == RowIndex && AlreadyDisplayedProgramEntryForIndex) {
302              string column = (button.Tag as string);              bool DoDisplay = false;
303              object data = dataGrid.DataSource;              if (CurrentRowIndex == -1)
304              XMLTV.CreateSorterFromDataSource(ref data, Descending, column);              {
305              dataGrid.DataSource = data;                  DoDisplay = true;
306              ToggleDescedning();              }
307          }              if (CurrentRowIndex == RowIndex)
308                {
309                    DoDisplay = false;
310                }
311                else
312                {
313                    DoDisplay = true;
314                }
315    
316          private void btnSortChannelName_Click(object sender, EventArgs e)              if (DoDisplay)
317          {              {
318              Button button = (sender as Button);                   CurrentRowIndex = RowIndex;
319              SortByColumn(button);                  List<IProgramDefinition> list = (dataGrid.DataSource as List<IProgramDefinition>);
320          }                  if (list == null)
321          private void btnSortChannelNumber_Click(object sender, EventArgs e)                  {
322          {                      gLog.Warn.WriteLine("Unable to display program entry for rowindex: {0}", RowIndex);
323              Button button = (sender as Button);                    
324              SortByColumn(button);                      return;
325          }                  }
326          private void btnSortStart_Click(object sender, EventArgs e)                  try
327          {                  {
328              Button button = (sender as Button);                      IProgramDefinition program = list[RowIndex];
329              SortByColumn(button);                      ProgramEntryControl c = new ProgramEntryControl(program);
330          }                      c.Dock = DockStyle.Fill;
331          private void btnSortStop_Click(object sender, EventArgs e)                      split_bottom.Panel2.Controls.Clear();
332          {                      split_bottom.Panel2.Controls.Add(c);                    
333              Button button = (sender as Button);                  }
334              SortByColumn(button);                  catch (Exception ex)
335          }                  {
336          private void btnSortTitle_Click(object sender, EventArgs e)                      gLog.Error.WriteLine(ex.ToString());
337          {                  }
338              Button button = (sender as Button);              }
             SortByColumn(button);  
         }  
         private void btnSortSubTitle_Click(object sender, EventArgs e)  
         {  
             Button button = (sender as Button);  
             SortByColumn(button);  
         }  
         private void btnSortDescription_Click(object sender, EventArgs e)  
         {  
             Button button = (sender as Button);  
             SortByColumn(button);  
339          }          }
340          #endregion          #endregion
341          private void FilterByColumn(RadioButton button)          #region Datasource support / events
         {  
             Type data_type;  
             string column = (button.Tag as string);  
             object data = XMLTV.CreateBindingSourceFromData(XMLTV.GetPrograms(), out data_type);  
             XMLTV.CreateFilterFromDataSource(ref data, column, txtFilterText.Text);  
             dataGrid.DataSource = data;  
         }  
         private void btnFilter_Click(object sender, EventArgs e)  
         {  
             RadioButton button = GetSelectedFilteringControl();  
             FilterByColumn(button);                    
         }  
   
342          private void dataGrid_SelectionChanged(object sender, EventArgs e)          private void dataGrid_SelectionChanged(object sender, EventArgs e)
343          {          {
344              try              try
# Line 326  namespace xmltv_parser Line 348  namespace xmltv_parser
348                  //var cell = dgv.SelectedCells[0];                  //var cell = dgv.SelectedCells[0];
349                  DataGridViewRow row = null;                  DataGridViewRow row = null;
350                  string data = string.Empty;                  string data = string.Empty;
351                  if (dgv.SelectedCells.Count > 0) { var cell = dgv.SelectedCells[0]; row = dgv.Rows[cell.RowIndex]; }                  if (dgv.SelectedCells.Count > 0)
352                  if (dgv.SelectedRows.Count > 0) { row = dgv.SelectedRows[0]; }                  {
353                  RadioButton button = GetSelectedFilteringControl();                      var cell = dgv.SelectedCells[0];
354                  data = row.Cells[GetColumnIndexForRadioButton(button)].Value.ToString();                      row = dgv.Rows[cell.RowIndex];
355                  txtFilterText.Text = data;                  }
356                    if (dgv.SelectedRows.Count > 0)
357                    {
358                        row = dgv.SelectedRows[0];
359                    }
360    
361                    if (row != null)
362                    {
363                        RadioButton button = GetSelectedFilteringControl();
364                        int index = GetColumnIndexForRadioButton(button);
365                        data = row.Cells[index].Value.ToString();
366                        txtFilterText.Text = data;
367                        DisplaySelectedProgramEntry(row);
368                    }
369              }              }
370              catch (Exception ex)              catch (Exception ex)
371              {              {
372                  gLog.Verbose.Error.WriteLine(ex.ToString());                  gLog.Verbose.Error.WriteLine(ex.ToString());
373              }              }
374          }          }
375            private int GetColumnIndexForRadioButton(RadioButton radio) { return GetColumnIndex(radio.Tag as string); }
376            private int GetColumnIndex(string columnname)
377            {
378                int index =0;
379                Type t = typeof(IProgramDefinition);
380    
381                var props = t.GetProperties();
382                foreach (var prop in props)
383                {
384                    if (prop.Name.ToLower() == columnname.ToLower()) { break; }
385                    index++;
386                }
387                return index;
388            }
389            #endregion
390            #region Reset event
391            private void btnResetSort_Click(object sender, EventArgs e)
392            {
393                Type data_type;
394                object datasource = XMLTV.CreateBindingSourceFromData(XMLTV.GetPrograms(), out data_type);
395                dataGrid.DataSource = datasource;
396                ToggleDescedning();
397            }
398            #endregion
399            #region Filtering events
400            private void FilterByColumn(RadioButton button)
401            {
402                Type data_type;
403                string column = (button.Tag as string);
404                object data = XMLTV.CreateBindingSourceFromData(XMLTV.GetPrograms(), out data_type);
405                XMLTV.CreateFilterFromDataSource(ref data, column, txtFilterText.Text);
406                dataGrid.DataSource = data;
407                dataGrid_SelectionChanged(dataGrid, new EventArgs());
408            }
409          private RadioButton GetSelectedFilteringControl()          private RadioButton GetSelectedFilteringControl()
410          {          {
411              bool control_selected = false;              bool control_selected = false;
412              RadioButton button = new RadioButton();              RadioButton button = new RadioButton();
413              foreach(var c in grpFilter_flow.Controls)              foreach (var c in grpFilter_flow.Controls)
414              {              {
415                  button = (c as RadioButton);                  button = (c as RadioButton);
416                  if (button != null) { if (button.Checked) { control_selected = true; break; } }                  if (button != null) { if (button.Checked) { control_selected = true; break; } }
# Line 350  namespace xmltv_parser Line 418  namespace xmltv_parser
418              }              }
419              if (!control_selected)              if (!control_selected)
420              {              {
421                  gLog.Warn.WriteLine("Unkown filter value used.  Was not: channelname, title, subtitle, or description.");                  gLog.Verbose.Warn.WriteLine("Unkown filter value used.  Was not: channelname, title, subtitle, description, start, or stop.");
422                  throw new InvalidOperationException("No filtering control is currently selected.");                  //throw new InvalidOperationException("No filtering control is currently selected.");
423                    return button;
424              }              }
425              else { return button; }              else { return button; }
426          }          }
         private int GetColumnIndexForRadioButton(RadioButton radio) { return GetColumnIndex(radio.Tag as string); }  
         private int GetColumnIndex(string columnname)  
         {  
             int index =0;  
             Type t = typeof(IProgramDefinition);  
   
             var props = t.GetProperties();  
             foreach (var prop in props)  
             {  
                 if (prop.Name.ToLower() == columnname.ToLower()) { break; }  
                 index++;  
             }  
             return index;  
         }  
   
427          private void UpdateFilterText(RadioButton radio, DataGridView dgv)          private void UpdateFilterText(RadioButton radio, DataGridView dgv)
428          {                      {
429              if (radio.Checked)              if (radio.Checked)
430              {              {
431                  int cellindex = GetColumnIndexForRadioButton(radio);                  int cellindex = GetColumnIndexForRadioButton(radio);
# Line 391  namespace xmltv_parser Line 445  namespace xmltv_parser
445                  txtFilterText.Text = data;                  txtFilterText.Text = data;
446              }              }
447          }          }
448            private void btnFilter_Click(object sender, EventArgs e)
449            {
450                RadioButton button = GetSelectedFilteringControl();
451                FilterByColumn(button);
452            }
453          private void radio_filter_channelnumber_CheckedChanged(object sender, EventArgs e)          private void radio_filter_channelnumber_CheckedChanged(object sender, EventArgs e)
454          {          {
455              RadioButton radio = (sender as RadioButton);              RadioButton radio = (sender as RadioButton);
# Line 401  namespace xmltv_parser Line 460  namespace xmltv_parser
460              RadioButton radio = (sender as RadioButton);              RadioButton radio = (sender as RadioButton);
461              UpdateFilterText(radio, dataGrid);              UpdateFilterText(radio, dataGrid);
462          }          }
   
463          private void radio_filter_subtitle_CheckedChanged(object sender, EventArgs e)          private void radio_filter_subtitle_CheckedChanged(object sender, EventArgs e)
464          {          {
465              RadioButton radio = (sender as RadioButton);              RadioButton radio = (sender as RadioButton);
466              UpdateFilterText(radio, dataGrid);              UpdateFilterText(radio, dataGrid);
467          }          }
   
468          private void radio_filter_description_CheckedChanged(object sender, EventArgs e)          private void radio_filter_description_CheckedChanged(object sender, EventArgs e)
469          {          {
470              RadioButton radio = (sender as RadioButton);              RadioButton radio = (sender as RadioButton);
471              UpdateFilterText(radio, dataGrid);              UpdateFilterText(radio, dataGrid);
472          }          }
   
473          private void radio_filter_channelname_CheckedChanged(object sender, EventArgs e)          private void radio_filter_channelname_CheckedChanged(object sender, EventArgs e)
474          {          {
475              RadioButton radio = (sender as RadioButton);              RadioButton radio = (sender as RadioButton);
476              UpdateFilterText(radio, dataGrid);              UpdateFilterText(radio, dataGrid);
477          }          }
   
478          private void radio_filter_start_CheckedChanged(object sender, EventArgs e)          private void radio_filter_start_CheckedChanged(object sender, EventArgs e)
479          {          {
480              RadioButton radio = (sender as RadioButton);              RadioButton radio = (sender as RadioButton);
# Line 429  namespace xmltv_parser Line 484  namespace xmltv_parser
484          {          {
485              RadioButton radio = (sender as RadioButton);              RadioButton radio = (sender as RadioButton);
486              UpdateFilterText(radio, dataGrid);              UpdateFilterText(radio, dataGrid);
487          }                }
488            private void radio_filter_rating_CheckedChanged(object sender, EventArgs e)
489            {
490                RadioButton radio = (sender as RadioButton);
491                UpdateFilterText(radio, dataGrid);
492            }
493            #endregion
494            #region Sorting events
495            private bool Descending = false;
496            private void ToggleDescedning() { Descending = Descending ? false : true; }
497            private void SortByColumn(RadioButton button)
498            {
499                string column = (button.Tag as string);
500                object data = dataGrid.DataSource;
501                XMLTV.CreateSorterFromDataSource(ref data, Descending, column);
502                dataGrid.DataSource = data;
503                ToggleDescedning();
504                dataGrid_SelectionChanged(dataGrid, new EventArgs());
505            }
506            private RadioButton GetSelectedSortControl()
507            {
508                bool control_selected = false;
509                RadioButton button = new RadioButton();
510                foreach (var c in grpSort_flow.Controls)
511                {
512                    button = (c as RadioButton);
513                    if (button != null) { if (button.Checked) { control_selected = true; break; } }
514                    else { continue; }
515                }
516                if (!control_selected)
517                {
518                    gLog.Warn.WriteLine("Unkown sort value used.  Was not: channelname, title, subtitle, description, stop, or start.");
519                    //throw new InvalidOperationException("No sorting control is currently selected.");
520                    return button;
521                }
522                else { return button; }
523            }
524            private void btnSort_Click(object sender, EventArgs e)
525            {
526                RadioButton button = GetSelectedSortControl();
527                SortByColumn(button);
528            }
529            #endregion
530    
531            private void dataGrid_Click(object sender, EventArgs e)
532            {
533                dataGrid_SelectionChanged(dataGrid, new EventArgs());
534            }
535    
536          
537      }      }
538  }  }
539    

Legend:
Removed from v.142  
changed lines
  Added in v.248

  ViewVC Help
Powered by ViewVC 1.1.22