/[xmltv_parser]/trunk/libxmltv/Core/XMLTVProgram.cs
ViewVC logotype

Diff of /trunk/libxmltv/Core/XMLTVProgram.cs

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

revision 90 by william, Sat Mar 9 17:42:34 2013 UTC revision 97 by william, Sun Mar 10 09:43:49 2013 UTC
# Line 43  namespace libxmltv.Core Line 43  namespace libxmltv.Core
43    
44          private void InternalDictionaryAddKnownProperties()          private void InternalDictionaryAddKnownProperties()
45          {          {
46              Properties = new PropertyDictionary();              MetaData = new PropertyDictionary();
47              Properties.AddProperty("Id", 0);              MetaData.AddProperty("Id", 0);
48              Properties.AddProperty(XMLTVConstants.Programs.ProgramStart, new DateTime());              MetaData.AddProperty(XMLTVConstants.Programs.ProgramStart, new DateTime());
49              Properties.AddProperty(XMLTVConstants.Programs.ProgramStop, new DateTime());              MetaData.AddProperty(XMLTVConstants.Programs.ProgramStop, new DateTime());
50              Properties.AddProperty(XMLTVConstants.Programs.ProgramChannelId, string.Empty);              MetaData.AddProperty(XMLTVConstants.Programs.ProgramChannelId, string.Empty);
51              Properties.AddProperty(XMLTVConstants.Programs.ProgramTitle, string.Empty);              MetaData.AddProperty(XMLTVConstants.Programs.ProgramTitle, string.Empty);
52              Properties.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, string.Empty);              MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, string.Empty);
53              Properties.AddProperty(XMLTVConstants.Programs.ProgramDescription, string.Empty);              MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, string.Empty);
54          }          }
55    
56          #region Property Dictionary Support          #region Property Dictionary Support
57          public PropertyDictionary Properties { get; private set; }          private PropertyDictionary _MetaData;
58            public PropertyDictionary MetaData { get { return _MetaData; } private set { _MetaData = value; } }
59          #endregion          #endregion
60    
61          #endregion          #endregion
62          public override string ToString()          public override string ToString()
63          {          {
64              return string.Format("{0}: {1} - {2} ({3}) ['{4}' <==> '{5}']",              return string.Format("{0}: {1} - {2} ({3}) ['{4}' <==> '{5}']",
65                  Properties["Id"].ToString(),                  MetaData["Id"].ToString(),
66                   Properties[(XMLTVConstants.Programs.ProgramTitle)].ToString(),                   MetaData[(XMLTVConstants.Programs.ProgramTitle)].ToString(),
67                   Properties[(XMLTVConstants.Programs.ProgramSubTitle)].ToString(),                   MetaData[(XMLTVConstants.Programs.ProgramSubTitle)].ToString(),
68                   Properties[(XMLTVConstants.Programs.ProgramChannelId)].ToString(),                   MetaData[(XMLTVConstants.Programs.ProgramChannelId)].ToString(),
69                  ((DateTime) Properties[XMLTVConstants.Programs.ProgramStart]).ToString("yyyy/MM/dd hh:mm tt"),                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStart]).ToString("yyyy/MM/dd hh:mm tt"),
70                  ((DateTime) Properties[XMLTVConstants.Programs.ProgramStop]).ToString("yyyy/MM/dd hh:mm tt"));                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStop]).ToString("yyyy/MM/dd hh:mm tt"));
71          }          }
72    
73    
# Line 86  namespace libxmltv.Core Line 87  namespace libxmltv.Core
87                      {                      {
88                                                    
89                          var list = (List<IXMLTVProgram>)field.GetValue(this.GetInstance());                          var list = (List<IXMLTVProgram>)field.GetValue(this.GetInstance());
90                          Properties["Id"] = list.Count + 1;                          MetaData["Id"] = list.Count + 1;
91                          list.Add(this);                          list.Add(this);
92                          xmltv_logger.Verbose.Debug.WriteLine("Updating instance with program information: {0}", this.ToString());                          xmltv_logger.Verbose.Debug.WriteLine("Updating instance with program information: {0}", this.ToString());
93                          field.SetValue(this.GetInstance(), list);                          field.SetValue(this.GetInstance(), list);
# Line 107  namespace libxmltv.Core Line 108  namespace libxmltv.Core
108    
109          private void Create(XElement node)          private void Create(XElement node)
110          {          {
111              //if (node.HasAttributes)              CreateHandlerForProgramMetaDataNode(node);
112              //{              var nodes = node.Elements().ToList();
             //    var start = node.Attribute(XMLTVConstants.Programs.ProgramStart);  
             //    this.Start = start == null ? new DateTime() : ParseDate(start.Value);  
             //    if (!this.Start.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start: {0}", start); }  
   
             //    var stop = node.Attribute(XMLTVConstants.Programs.ProgramStop);  
             //    this.Stop = stop == null ? new DateTime() : ParseDate(stop.Value);  
             //    if (!this.Stop.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop: {0}", stop); }  
   
             //    var channelid = node.Attribute(XMLTVConstants.Programs.ProgramChannelId);  
             //    if (!string.IsNullOrEmpty(this.channelid)) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_channelid: {0}", channelid); }  
             //    IXMLTVChannel channel = new XMLTVChannel();  
             //    string _channelid = channelid == null ? string.Empty : channelid.Value;  
             //    this.Channel = this.GetInstance().Channels.Find(m => m.Id == _channelid);  
             //    if (this.Channel == null) { this.Channel = new XMLTVChannel(); }  
             //    if (!string.IsNullOrEmpty(_channelid)) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_channel: {0}", this.Channel.ToString()); }            //}  
             //try  
             //{  
             //    var title = node.Descendants(XMLTVConstants.Programs.ProgramTitle).FirstOrDefault();  
             //    this.Title = title == null ? string.Empty : title.Value;  
             //}  
             //catch (Exception) { this.Title = string.Empty; }  
             //if (!string.IsNullOrEmpty(this.Title)) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_title: {0}", this.Title == string.Empty ? "empty" : this.Title); }  
             //try  
             //{  
             //    var subtitle = node.Descendants(XMLTVConstants.Programs.ProgramSubTitle).FirstOrDefault();  
             //    this.SubTitle = subtitle == null ? string.Empty : subtitle.Value;  
             //}  
             //catch (Exception) { this.SubTitle = string.Empty; }  
             //if (!string.IsNullOrEmpty(this.SubTitle)) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", this.SubTitle == string.Empty ? "empty" : this.SubTitle); }  
             //try  
             //{  
             //    var description = node.Descendants(XMLTVConstants.Programs.ProgramDescription).FirstOrDefault();  
             //    this.Description = description == null ? string.Empty : description.Value; ;  
             //}  
             //catch (Exception) { this.Description = string.Empty; }  
             //if (!string.IsNullOrEmpty(this.Description)) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", this.Description == string.Empty ? "empty" : this.Description); }  
   
             //ParseExtraData(node);  
   
             var nodes = node.DescendantsAndSelf().ToList();  
113              foreach (var sub_node in nodes)              foreach (var sub_node in nodes)
114              {              {
115                  if (this.GetInstance().IsAborting)                  if (this.GetInstance().IsAborting)
# Line 242  namespace libxmltv.Core Line 203  namespace libxmltv.Core
203                  if(node == null){throw new NullReferenceException("The node instance was null");}                                  if(node == null){throw new NullReferenceException("The node instance was null");}                
204                  if (node.Value != null)                  if (node.Value != null)
205                  {                  {
206                      instance.Properties.AddProperty(XMLTVConstants.Programs.ProgramTitle, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramTitle, node.Value);
207                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_title: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_title: {0}", node.Value);
208                  }                                  }                
209              }              }
# Line 261  namespace libxmltv.Core Line 222  namespace libxmltv.Core
222                      var start = node.Attribute(XMLTVConstants.Programs.ProgramStart);                      var start = node.Attribute(XMLTVConstants.Programs.ProgramStart);
223                      var t_start = start == null ? new DateTime() : ParseDate(start.Value);                      var t_start = start == null ? new DateTime() : ParseDate(start.Value);
224                      if (!t_start.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start: {0}", start); }                      if (!t_start.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start: {0}", start); }
225                      instance.Properties.AddProperty(XMLTVConstants.Programs.ProgramStart, t_start);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStart, t_start);
226    
227                      var stop = node.Attribute(XMLTVConstants.Programs.ProgramStop);                      var stop = node.Attribute(XMLTVConstants.Programs.ProgramStop);
228                      var t_stop = stop == null ? new DateTime() : ParseDate(stop.Value);                      var t_stop = stop == null ? new DateTime() : ParseDate(stop.Value);
229                      if (!t_stop.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop: {0}", stop); }                      if (!t_stop.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop: {0}", stop); }
230                      instance.Properties.AddProperty(XMLTVConstants.Programs.ProgramStop, t_stop);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStop, t_stop);
231    
232                      var channelid = node.Attribute(XMLTVConstants.Programs.ProgramChannelId);                      var channelid = node.Attribute(XMLTVConstants.Programs.ProgramChannelId);
233                      if (channelid != null)                      if (channelid != null)
234                      {                      {
235                          if (!string.IsNullOrEmpty(channelid.Value)) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_channelid: {0}", channelid.Value); }                          if (!string.IsNullOrEmpty(channelid.Value)) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_channelid: {0}", channelid.Value); }
236                          instance.Properties.AddProperty(XMLTVConstants.Programs.ProgramChannelId, channelid.Value);                          instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramChannelId, channelid.Value);
237                      }                      }
238                                            
239                  }                  }
# Line 290  namespace libxmltv.Core Line 251  namespace libxmltv.Core
251                  if (node == null) { throw new NullReferenceException("The node instance was null"); }                  if (node == null) { throw new NullReferenceException("The node instance was null"); }
252                  if (node.Value != null)                  if (node.Value != null)
253                  {                  {
254                      instance.Properties.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);
255                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);
256                  }                  }
257              }              }
# Line 306  namespace libxmltv.Core Line 267  namespace libxmltv.Core
267                  if (node == null) { throw new NullReferenceException("The node instance was null"); }                  if (node == null) { throw new NullReferenceException("The node instance was null"); }
268                  if (node.Value != null)                  if (node.Value != null)
269                  {                  {
270                      instance.Properties.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);
271                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);
272                  }                  }
273              }              }

Legend:
Removed from v.90  
changed lines
  Added in v.97

  ViewVC Help
Powered by ViewVC 1.1.22