/[xmltv_parser]/branches/linux/xmltv_parser/libxmltv/Core/XMLTVProgram.cs
ViewVC logotype

Diff of /branches/linux/xmltv_parser/libxmltv/Core/XMLTVProgram.cs

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

revision 86 by william, Sat Mar 9 13:51:58 2013 UTC revision 104 by william, Sun Mar 10 11:10:30 2013 UTC
# Line 14  namespace libxmltv.Core Line 14  namespace libxmltv.Core
14      [Serializable]      [Serializable]
15      internal class XMLTVProgram : XMLTVBase<XMLTVRuntimeInstance>, IXMLTVProgram      internal class XMLTVProgram : XMLTVBase<XMLTVRuntimeInstance>, IXMLTVProgram
16      {      {
17          public XMLTVProgram() : base(null,XMLTVConstants.PROGRAM_ELEMENT)          public XMLTVProgram()
18                : base(null, XMLTVConstants.Programs.RootElement)
19          {          {
20              InternalDictionaryAddKnownProperties();              InternalDictionaryAddKnownProperties();
21                    
22          }          }
23          public XMLTVProgram(XMLTVRuntimeInstance instance, XElement node)          public XMLTVProgram(XMLTVRuntimeInstance instance, XElement node)
24              : base(instance, XMLTVConstants.PROGRAM_ELEMENT)              : base(instance, XMLTVConstants.Programs.RootElement)
25          {          {
26              InternalDictionaryAddKnownProperties();              InternalDictionaryAddKnownProperties();
27              try {              try {
# Line 42  namespace libxmltv.Core Line 43  namespace libxmltv.Core
43    
44          private void InternalDictionaryAddKnownProperties()          private void InternalDictionaryAddKnownProperties()
45          {          {
46              Properties = new Dictionary<string, object>();              MetaData = new PropertyDictionary();
47              Properties.Add("Id", 0);              MetaData.AddProperty("Id", 0);
48              Properties.Add(XMLTVConstants.Programs.ProgramStart, new DateTime());              MetaData.AddProperty(XMLTVConstants.Programs.ProgramStart, new DateTime());
49              Properties.Add(XMLTVConstants.Programs.ProgramStop, new DateTime());              MetaData.AddProperty(XMLTVConstants.Programs.ProgramStop, new DateTime());
50              Properties.Add(XMLTVConstants.Programs.ProgramChannelId, string.Empty);              MetaData.AddProperty(XMLTVConstants.Programs.ProgramChannelId, string.Empty);
51              Properties.Add(XMLTVConstants.Programs.ProgramTitle, string.Empty);              MetaData.AddProperty(XMLTVConstants.Programs.ProgramTitle, string.Empty);
52              Properties.Add(XMLTVConstants.Programs.ProgramSubTitle, string.Empty);              MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, string.Empty);
53              Properties.Add(XMLTVConstants.Programs.ProgramDescription, string.Empty);              MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, string.Empty);
54          }          }
55    
56          public Dictionary<string, object> Properties { get; private set; }          #region Property Dictionary Support
57            private PropertyDictionary _MetaData;
58            public PropertyDictionary MetaData { get { return _MetaData; } private set { _MetaData = value; } }
59            #endregion
60    
         private void InternalDictionaryTestOrThrow()  
         {  
             if (Properties == null) { throw new NullReferenceException("Properties collection has not been initialized."); }  
             if (Properties.Count == 0) { throw new IndexOutOfRangeException("Properties collection has 0 elements."); }  
         }  
         private void InternalProperyExistsOrThrow(string name)  
         {  
             InternalDictionaryTestOrThrow();  
             if (!Properties.ContainsKey(name)) { throw new KeyNotFoundException(string.Format("Property '{0}' does not exist", name)); }  
         }  
         public object GetProperty(string name)  
         {  
             InternalProperyExistsOrThrow(name);  
             return Properties[name];              
         }  
         public void SetProperty(string name, object value)  
         {  
             InternalProperyExistsOrThrow(name);  
             Properties[name] = value;  
         }  
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                  GetProperty("Id").ToString(),                  MetaData["Id"].ToString(),
66                  GetProperty(XMLTVConstants.Programs.ProgramTitle).ToString(),                   MetaData[XMLTVConstants.Programs.ProgramTitle].ToString(),
67                  GetProperty(XMLTVConstants.Programs.ProgramSubTitle), ToString(),                   MetaData[XMLTVConstants.Programs.ProgramSubTitle].ToString(),
68                  GetProperty(XMLTVConstants.Programs.ProgramChannelId).ToString(),                   MetaData[XMLTVConstants.Programs.ProgramChannelId].ToString(),
69                  ((DateTime)GetProperty(XMLTVConstants.Programs.ProgramStart)).ToString("yyyy/MM/dd hh:mm tt"),                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStart]).ToString("yyyy/MM/dd hh:mm tt"),
70                  ((DateTime)GetProperty(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 103  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                          this.SetProperty("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 124  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);
             //{  
             //    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.Description)) { 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);  
   
112              var nodes = node.Elements().ToList();              var nodes = node.Elements().ToList();
113              foreach (var sub_node in nodes)              foreach (var sub_node in nodes)
114              {              {
# Line 175  namespace libxmltv.Core Line 119  namespace libxmltv.Core
119                  CreateHandlerForProgramMetaDataNode(sub_node);                  CreateHandlerForProgramMetaDataNode(sub_node);
120              }              }
121          }          }
122          private DateTime ParseDate(string timeStamp)          private static DateTime ParseDate(string timeStamp)
123          {          {
124              DateTime dt = new DateTime();              DateTime dt = new DateTime();
125              try              try
# Line 188  namespace libxmltv.Core Line 132  namespace libxmltv.Core
132    
133          private void CreateHandlerForProgramMetaDataNode(XElement node)          private void CreateHandlerForProgramMetaDataNode(XElement node)
134          {          {
135    
136              Type t = this.GetType();              Type t = this.GetType();
137              Assembly asm = t.Assembly;              Assembly asm = t.Assembly;
138              var types = asm.GetTypes();              var types = asm.GetTypes();
# Line 239  namespace libxmltv.Core Line 184  namespace libxmltv.Core
184                  string node_text = string.Format("{0}>", node_builder.ToString().TrimEnd(new char[] { ' ' }));                  string node_text = string.Format("{0}>", node_builder.ToString().TrimEnd(new char[] { ' ' }));
185                  xmltv_logger.Verbose.Warn.WriteLine("Ignoring unhandled extra meta-data: {0}", node_text);                  xmltv_logger.Verbose.Warn.WriteLine("Ignoring unhandled extra meta-data: {0}", node_text);
186              }              }
187              raw_instance = Activator.CreateInstance(handler_type, flags, null, new object[] { this, node }, culture);              else
188                {
189                    raw_instance = Activator.CreateInstance(handler_type, flags, null, new object[] { this, node }, culture);
190                }
191          }          }
192    
193    
194    
195          #region sub-classes          #region sub-classes
196            #region program title
197          private class title : XMLTVBase<XMLTVProgram>          private class title : XMLTVBase<XMLTVProgram>
198          {          {
199              public title() : base(null, XMLTVConstants.Programs.ProgramTitle) { }              public title() : base(null, XMLTVConstants.Programs.ProgramTitle) { }
200              public title(XMLTVProgram instance, XElement node)              public title(XMLTVProgram instance, XElement node)
201                  : base(instance, XMLTVConstants.Programs.ProgramTitle)                  : base(instance, XMLTVConstants.Programs.ProgramTitle)
202                {                
203                    if(node == null){throw new NullReferenceException("The node instance was null");}                
204                    if (node.Value != null)
205                    {
206                        instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramTitle, node.Value);
207                        xmltv_logger.Verbose.Debug.WriteLine("\tprogram_title: {0}", node.Value);
208                    }                
209                }
210            }
211            #endregion
212            #region program stop/start/channel (programme)
213            private class programme : XMLTVBase<XMLTVProgram>
214            {
215                public programme() : base(null, XMLTVConstants.Programs.RootElement) { }
216                public programme(XMLTVProgram instance, XElement node)
217                    : base(instance, XMLTVConstants.Programs.RootElement)
218              {              {
219                    if (node == null) { throw new NullReferenceException("The node instance was null"); }
220                    if (node.HasAttributes)
221                    {                    
222                        var start = node.Attribute(XMLTVConstants.Programs.ProgramStart);
223                        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); }
225                        instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStart, t_start);
226    
227                        var stop = node.Attribute(XMLTVConstants.Programs.ProgramStop);
228                        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); }
230                        instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStop, t_stop);
231    
232                        var channelid = node.Attribute(XMLTVConstants.Programs.ProgramChannelId);
233                        if (channelid != null)
234                        {
235                            if (!string.IsNullOrEmpty(channelid.Value)) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_channelid: {0}", channelid.Value); }
236                            instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramChannelId, channelid.Value);
237                        }
238                        
239                    }
240              }              }
241          }          }
242          #endregion          #endregion
243    
244            #region sub title
245            private class subtitle : XMLTVBase<XMLTVProgram>
246            {
247                public subtitle() : base(null, XMLTVConstants.Programs.ProgramSubTitle) { }
248                public subtitle(XMLTVProgram instance, XElement node)
249                    : base(instance, XMLTVConstants.Programs.ProgramSubTitle)
250                {
251                    if (node == null) { throw new NullReferenceException("The node instance was null"); }
252                    if (node.Value != null)
253                    {
254                        instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);
255                        xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);
256                    }
257                }
258            }
259            #endregion
260            #region sub title
261            private class description : XMLTVBase<XMLTVProgram>
262            {
263                public description() : base(null, XMLTVConstants.Programs.ProgramDescription) { }
264                public description(XMLTVProgram instance, XElement node)
265                    : base(instance, XMLTVConstants.Programs.ProgramDescription)
266                {
267                    if (node == null) { throw new NullReferenceException("The node instance was null"); }
268                    if (node.Value != null)
269                    {
270                        instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);
271                        xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);
272                    }
273                }
274            }
275            #endregion
276            #endregion
277      }      }
278  }  }

Legend:
Removed from v.86  
changed lines
  Added in v.104

  ViewVC Help
Powered by ViewVC 1.1.22