/[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

trunk/libxmltv/Core/XMLTVProgram.cs revision 91 by william, Sat Mar 9 17:48:02 2013 UTC branches/linux/xmltv_parser/libxmltv/Core/XMLTVProgram.cs revision 298 by william, Fri Dec 14 19:38:41 2018 UTC
# Line 54  namespace libxmltv.Core Line 54  namespace libxmltv.Core
54          }          }
55    
56          #region Property Dictionary Support          #region Property Dictionary Support
57          public PropertyDictionary MetaData { get; private set; }          private IPropertyDictionary _MetaData;
58            public IPropertyDictionary MetaData { get { return _MetaData; } private set { _MetaData = value; } }
59            public List<IExtraMetaData> GetExtraMetaData()
60            {
61                    if (this.MetaData.ContainsProperty (XMLTVConstants.Programs.ProgramExtraMetaData)) {
62                            return (List<IExtraMetaData>)this.MetaData [XMLTVConstants.Programs.ProgramExtraMetaData];
63                    } else {
64                            return new List<IExtraMetaData>();
65                    }
66            }
67          #endregion          #endregion
68    
69          #endregion          #endregion
# Line 62  namespace libxmltv.Core Line 71  namespace libxmltv.Core
71          {          {
72              return string.Format("{0}: {1} - {2} ({3}) ['{4}' <==> '{5}']",              return string.Format("{0}: {1} - {2} ({3}) ['{4}' <==> '{5}']",
73                  MetaData["Id"].ToString(),                  MetaData["Id"].ToString(),
74                   MetaData[(XMLTVConstants.Programs.ProgramTitle)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramTitle].ToString(),
75                   MetaData[(XMLTVConstants.Programs.ProgramSubTitle)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramSubTitle].ToString(),
76                   MetaData[(XMLTVConstants.Programs.ProgramChannelId)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramChannelId].ToString(),
77                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStart]).ToString("yyyy/MM/dd hh:mm tt"),                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStart]).ToDateTimeString(),
78                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStop]).ToString("yyyy/MM/dd hh:mm tt"));                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStop]).ToDateTimeString());
79          }          }
80    
81    
# Line 79  namespace libxmltv.Core Line 88  namespace libxmltv.Core
88              var fields = instance_type.GetFields(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance);              var fields = instance_type.GetFields(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance);
89              foreach (var field in fields)              foreach (var field in fields)
90              {              {
91                  if (field.FieldType == typeof(List<IXMLTVProgram>))                  if (field.FieldType == typeof(ProgramList))
92                  {                  {
93                      found_field = true;                      found_field = true;
94                      try                      try
95                      {                      {
96                            
97                          var list = (List<IXMLTVProgram>)field.GetValue(this.GetInstance());                          var list = (ProgramList)field.GetValue(this.GetInstance());
98                          MetaData["Id"] = list.Count + 1;                          MetaData["Id"] = list.Count + 1;
99                          list.Add(this);                          list.Add(this);
100                          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());
# Line 107  namespace libxmltv.Core Line 116  namespace libxmltv.Core
116    
117          private void Create(XElement node)          private void Create(XElement node)
118          {          {
119              var nodes = node.DescendantsAndSelf().ToList();              CreateHandlerForProgramMetaDataNode(node);
120                var nodes = node.Elements().ToList();
121              foreach (var sub_node in nodes)              foreach (var sub_node in nodes)
122              {              {
123                  if (this.GetInstance().IsAborting)                  if (this.GetInstance().IsAborting)
# Line 159  namespace libxmltv.Core Line 169  namespace libxmltv.Core
169                              var ctors = type.GetConstructors(flags);                              var ctors = type.GetConstructors(flags);
170                              bool has_default_ctor = false;                              bool has_default_ctor = false;
171                              foreach (var ctor in ctors) { if (ctor.GetParameters().Count() == 0) { has_default_ctor = true; } }                              foreach (var ctor in ctors) { if (ctor.GetParameters().Count() == 0) { has_default_ctor = true; } }
172                                ctors = null;
173                              if (!has_default_ctor) { continue; }                              if (!has_default_ctor) { continue; }
174                              raw_instance = Activator.CreateInstance(type, flags, null, new object[0], culture);                              raw_instance = Activator.CreateInstance(type, flags, null, new object[0], culture);
175                              if (raw_instance != null)                              if (raw_instance != null)
# Line 167  namespace libxmltv.Core Line 178  namespace libxmltv.Core
178                                  if (handler_value != null && handler_value.ToString() == node.Name.ToString())                                  if (handler_value != null && handler_value.ToString() == node.Name.ToString())
179                                  {                                  {
180                                      handler_type = type;                                      handler_type = type;
181                                        handler_value = null;
182                                        raw_instance = null;
183                                        handler_prop = null;
184                                        iface = null;
185                                      break;                                      break;
186                                  }                                  }
187                                    handler_value = null;
188                              }                              }
189                                raw_instance = null;
190                          }                          }
191                            handler_prop = null;
192                      }                      }
193                        iface = null;
194                  }                  }
195              }              }
196                t = null;
197                asm = null;
198                types = null;
199                classes = null;
200              if (handler_type == null)              if (handler_type == null)
201              {              {
202                  StringBuilder node_builder = new StringBuilder();                  try
203                  node_builder.AppendFormat("<{0} ", node.Name);                  {
204                  if (node.HasAttributes) { foreach (var attribute in node.Attributes()) { node_builder.AppendFormat("{0}=\"{1}\" ", attribute.Name, attribute.Value); } }                      raw_instance = Activator.CreateInstance(typeof(UnhandledExtraProgramMetaData), flags, null, new object[] { this, node }, culture);
205                  string node_text = string.Format("{0}>", node_builder.ToString().TrimEnd(new char[] { ' ' }));                  }
206                  xmltv_logger.Verbose.Warn.WriteLine("Ignoring unhandled extra meta-data: {0}", node_text);                  catch (Exception ex) { throw ex; }
207    
208                    if (raw_instance == null)
209                    {
210                        StringBuilder node_builder = new StringBuilder();
211                        node_builder.AppendFormat("<{0} ", node.Name);
212                        if (node.HasAttributes) { foreach (var attribute in node.Attributes()) { node_builder.AppendFormat("{0}=\"{1}\" ", attribute.Name, attribute.Value); } }
213                        string node_text = string.Format("{0}>", node_builder.ToString().TrimEnd(new char[] { ' ' }));
214                        xmltv_logger.Verbose.Warn.WriteLine("Ignoring unhandled extra meta-data: {0}", node_text);
215                    }
216              }              }
217              else              else
218              {              {
219                  raw_instance = Activator.CreateInstance(handler_type, flags, null, new object[] { this, node }, culture);                  try
220                    {
221                        raw_instance = Activator.CreateInstance(handler_type, flags, null, new object[] { this, node }, culture);
222                    }
223                    catch (Exception ex) { throw ex; }
224              }              }
225                raw_instance = null;
226                flags = 0;
227                culture = null;
228                node = null;
229          }          }
230    
231    
232    
233          #region sub-classes          #region sub-classes      
234          #region program title          #region programme: stop/start/channelid
         private class title : XMLTVBase<XMLTVProgram>  
         {  
             public title() : base(null, XMLTVConstants.Programs.ProgramTitle) { }  
             public title(XMLTVProgram instance, XElement node)  
                 : base(instance, XMLTVConstants.Programs.ProgramTitle)  
             {                  
                 if(node == null){throw new NullReferenceException("The node instance was null");}                  
                 if (node.Value != null)  
                 {  
                     instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramTitle, node.Value);  
                     xmltv_logger.Verbose.Debug.WriteLine("\tprogram_title: {0}", node.Value);  
                 }                  
             }  
         }  
         #endregion  
         #region program stop/start/channel (programme)  
235          private class programme : XMLTVBase<XMLTVProgram>          private class programme : XMLTVBase<XMLTVProgram>
236          {          {
237              public programme() : base(null, XMLTVConstants.Programs.RootElement) { }              public programme() : base(null, XMLTVConstants.Programs.RootElement) { }
# Line 219  namespace libxmltv.Core Line 243  namespace libxmltv.Core
243                  {                                      {                    
244                      var start = node.Attribute(XMLTVConstants.Programs.ProgramStart);                      var start = node.Attribute(XMLTVConstants.Programs.ProgramStart);
245                      var t_start = start == null ? new DateTime() : ParseDate(start.Value);                      var t_start = start == null ? new DateTime() : ParseDate(start.Value);
246                      if (!t_start.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start: {0}", start); }                      if (!t_start.Equals(new DateTime()))
247                        {
248                            xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start: {0}", start);
249                            xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start dt: {0}", t_start.ToString());
250                        }
251                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStart, t_start);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStart, t_start);
252    
253                      var stop = node.Attribute(XMLTVConstants.Programs.ProgramStop);                      var stop = node.Attribute(XMLTVConstants.Programs.ProgramStop);
254                      var t_stop = stop == null ? new DateTime() : ParseDate(stop.Value);                      var t_stop = stop == null ? new DateTime() : ParseDate(stop.Value);
255                      if (!t_stop.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop: {0}", stop); }                      if (!t_stop.Equals(new DateTime()))
256                        {
257                            xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop: {0}", stop);
258                            xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop dt: {0}", t_stop.ToString());
259                        }
260                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStop, t_stop);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStop, t_stop);
261    
262                      var channelid = node.Attribute(XMLTVConstants.Programs.ProgramChannelId);                      var channelid = node.Attribute(XMLTVConstants.Programs.ProgramChannelId);
# Line 235  namespace libxmltv.Core Line 267  namespace libxmltv.Core
267                      }                      }
268                                            
269                  }                  }
270                    node = null;
271              }              }
272          }          }
273          #endregion          #endregion
274            #region title
275          #region sub title          private class title : XMLTVBase<XMLTVProgram>
276            {
277                public title() : base(null, XMLTVConstants.Programs.ProgramTitle) { }
278                public title(XMLTVProgram instance, XElement node)
279                    : base(instance, XMLTVConstants.Programs.ProgramTitle)
280                {
281                    if (node == null) { throw new NullReferenceException("The node instance was null"); }
282                    if (node.Value != null)
283                    {
284                        instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramTitle, node.Value);
285                        xmltv_logger.Verbose.Debug.WriteLine("\tprogram_title: {0}", node.Value);
286                    }
287                    node = null;
288                }
289            }
290            #endregion
291            #region sub-title
292          private class subtitle : XMLTVBase<XMLTVProgram>          private class subtitle : XMLTVBase<XMLTVProgram>
293          {          {
294              public subtitle() : base(null, XMLTVConstants.Programs.ProgramSubTitle) { }              public subtitle() : base(null, XMLTVConstants.Programs.ProgramSubTitle) { }
# Line 252  namespace libxmltv.Core Line 301  namespace libxmltv.Core
301                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);
302                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);
303                  }                  }
304                    node = null;
305              }              }
306          }          }
307          #endregion          #endregion
308          #region sub title          #region description
309          private class description : XMLTVBase<XMLTVProgram>          private class description : XMLTVBase<XMLTVProgram>
310          {          {
311              public description() : base(null, XMLTVConstants.Programs.ProgramDescription) { }              public description() : base(null, XMLTVConstants.Programs.ProgramDescription) { }
# Line 268  namespace libxmltv.Core Line 318  namespace libxmltv.Core
318                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);
319                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);
320                  }                  }
321                    node = null;
322              }              }
323          }          }
324          #endregion          #endregion
325    
326            #region UnhandledExtraMetaData
327            private class UnhandledExtraProgramMetaData : XMLTVBase<XMLTVProgram>
328            {
329                public UnhandledExtraProgramMetaData() : base(null, null) { }
330                public UnhandledExtraProgramMetaData(XMLTVProgram instance, XElement node)
331                    : base(instance, null)
332                {
333                    if (node == null) { throw new NullReferenceException("The node instance was null"); }      
334                    xmltv_logger.Verbose.Debug.WriteLine("Parsng unhandled extra program meta-data: {0}", node.Name.ToString());
335                    if (this.GetInstance() != null)
336                    {
337                        List<IExtraMetaData> list = new List<IExtraMetaData>();
338                        if (!instance.MetaData.ContainsProperty(XMLTVConstants.Programs.ProgramExtraMetaData)) { instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramExtraMetaData, new List<ExtraMetaData>()); }
339                        else { list = (List<IExtraMetaData>)instance.MetaData[XMLTVConstants.Programs.ProgramExtraMetaData]; }
340                        ExtraMetaData data = new ExtraMetaData(node);
341                        list.Add(data);
342                        instance.MetaData[XMLTVConstants.Programs.ProgramExtraMetaData] = list;
343                        data = null;
344                    }
345                    node = null;
346                }
347            }      
348            #endregion
349          #endregion          #endregion
350      }      }
351  }  }

Legend:
Removed from v.91  
changed lines
  Added in v.298

  ViewVC Help
Powered by ViewVC 1.1.22