/[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 97 by william, Sun Mar 10 09:43:49 2013 UTC branches/linux/xmltv_parser/libxmltv/Core/XMLTVProgram.cs revision 282 by william, Wed Jul 29 19:09:14 2015 UTC
# Line 54  namespace libxmltv.Core Line 54  namespace libxmltv.Core
54          }          }
55    
56          #region Property Dictionary Support          #region Property Dictionary Support
57          private PropertyDictionary _MetaData;          private IPropertyDictionary _MetaData;
58          public PropertyDictionary MetaData { get { return _MetaData; } private set { _MetaData = value; } }          public IPropertyDictionary MetaData { get { return _MetaData; } private set { _MetaData = value; } }
59            public List<IExtraMetaData> GetExtraMetaData()
60            {
61                return (List<IExtraMetaData>)this.MetaData[XMLTVConstants.Programs.ProgramExtraMetaData];
62            }
63          #endregion          #endregion
64    
65          #endregion          #endregion
# Line 63  namespace libxmltv.Core Line 67  namespace libxmltv.Core
67          {          {
68              return string.Format("{0}: {1} - {2} ({3}) ['{4}' <==> '{5}']",              return string.Format("{0}: {1} - {2} ({3}) ['{4}' <==> '{5}']",
69                  MetaData["Id"].ToString(),                  MetaData["Id"].ToString(),
70                   MetaData[(XMLTVConstants.Programs.ProgramTitle)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramTitle].ToString(),
71                   MetaData[(XMLTVConstants.Programs.ProgramSubTitle)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramSubTitle].ToString(),
72                   MetaData[(XMLTVConstants.Programs.ProgramChannelId)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramChannelId].ToString(),
73                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStart]).ToString("yyyy/MM/dd hh:mm tt"),                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStart]).ToDateTimeString(),
74                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStop]).ToString("yyyy/MM/dd hh:mm tt"));                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStop]).ToDateTimeString());
75          }          }
76    
77    
# Line 80  namespace libxmltv.Core Line 84  namespace libxmltv.Core
84              var fields = instance_type.GetFields(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance);              var fields = instance_type.GetFields(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance);
85              foreach (var field in fields)              foreach (var field in fields)
86              {              {
87                  if (field.FieldType == typeof(List<IXMLTVProgram>))                  if (field.FieldType == typeof(ProgramList))
88                  {                  {
89                      found_field = true;                      found_field = true;
90                      try                      try
91                      {                      {
92                            
93                          var list = (List<IXMLTVProgram>)field.GetValue(this.GetInstance());                          var list = (ProgramList)field.GetValue(this.GetInstance());
94                          MetaData["Id"] = list.Count + 1;                          MetaData["Id"] = list.Count + 1;
95                          list.Add(this);                          list.Add(this);
96                          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 161  namespace libxmltv.Core Line 165  namespace libxmltv.Core
165                              var ctors = type.GetConstructors(flags);                              var ctors = type.GetConstructors(flags);
166                              bool has_default_ctor = false;                              bool has_default_ctor = false;
167                              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; } }
168                                ctors = null;
169                              if (!has_default_ctor) { continue; }                              if (!has_default_ctor) { continue; }
170                              raw_instance = Activator.CreateInstance(type, flags, null, new object[0], culture);                              raw_instance = Activator.CreateInstance(type, flags, null, new object[0], culture);
171                              if (raw_instance != null)                              if (raw_instance != null)
# Line 169  namespace libxmltv.Core Line 174  namespace libxmltv.Core
174                                  if (handler_value != null && handler_value.ToString() == node.Name.ToString())                                  if (handler_value != null && handler_value.ToString() == node.Name.ToString())
175                                  {                                  {
176                                      handler_type = type;                                      handler_type = type;
177                                        handler_value = null;
178                                        raw_instance = null;
179                                        handler_prop = null;
180                                        iface = null;
181                                      break;                                      break;
182                                  }                                  }
183                                    handler_value = null;
184                              }                              }
185                                raw_instance = null;
186                          }                          }
187                            handler_prop = null;
188                      }                      }
189                        iface = null;
190                  }                  }
191              }              }
192                t = null;
193                asm = null;
194                types = null;
195                classes = null;
196              if (handler_type == null)              if (handler_type == null)
197              {              {
198                  StringBuilder node_builder = new StringBuilder();                  try
199                  node_builder.AppendFormat("<{0} ", node.Name);                  {
200                  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);
201                  string node_text = string.Format("{0}>", node_builder.ToString().TrimEnd(new char[] { ' ' }));                  }
202                  xmltv_logger.Verbose.Warn.WriteLine("Ignoring unhandled extra meta-data: {0}", node_text);                  catch (Exception ex) { throw ex; }
203    
204                    if (raw_instance == null)
205                    {
206                        StringBuilder node_builder = new StringBuilder();
207                        node_builder.AppendFormat("<{0} ", node.Name);
208                        if (node.HasAttributes) { foreach (var attribute in node.Attributes()) { node_builder.AppendFormat("{0}=\"{1}\" ", attribute.Name, attribute.Value); } }
209                        string node_text = string.Format("{0}>", node_builder.ToString().TrimEnd(new char[] { ' ' }));
210                        xmltv_logger.Verbose.Warn.WriteLine("Ignoring unhandled extra meta-data: {0}", node_text);
211                    }
212              }              }
213              else              else
214              {              {
215                  raw_instance = Activator.CreateInstance(handler_type, flags, null, new object[] { this, node }, culture);                  try
216                    {
217                        raw_instance = Activator.CreateInstance(handler_type, flags, null, new object[] { this, node }, culture);
218                    }
219                    catch (Exception ex) { throw ex; }
220              }              }
221                raw_instance = null;
222                flags = 0;
223                culture = null;
224                node = null;
225          }          }
226    
227    
228    
229          #region sub-classes          #region sub-classes      
230          #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)  
231          private class programme : XMLTVBase<XMLTVProgram>          private class programme : XMLTVBase<XMLTVProgram>
232          {          {
233              public programme() : base(null, XMLTVConstants.Programs.RootElement) { }              public programme() : base(null, XMLTVConstants.Programs.RootElement) { }
# Line 221  namespace libxmltv.Core Line 239  namespace libxmltv.Core
239                  {                                      {                    
240                      var start = node.Attribute(XMLTVConstants.Programs.ProgramStart);                      var start = node.Attribute(XMLTVConstants.Programs.ProgramStart);
241                      var t_start = start == null ? new DateTime() : ParseDate(start.Value);                      var t_start = start == null ? new DateTime() : ParseDate(start.Value);
242                      if (!t_start.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start: {0}", start); }                      if (!t_start.Equals(new DateTime()))
243                        {
244                            xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start: {0}", start);
245                            xmltv_logger.Verbose.Debug.WriteLine("\tprogram_start dt: {0}", t_start.ToString());
246                        }
247                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStart, t_start);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStart, t_start);
248    
249                      var stop = node.Attribute(XMLTVConstants.Programs.ProgramStop);                      var stop = node.Attribute(XMLTVConstants.Programs.ProgramStop);
250                      var t_stop = stop == null ? new DateTime() : ParseDate(stop.Value);                      var t_stop = stop == null ? new DateTime() : ParseDate(stop.Value);
251                      if (!t_stop.Equals(new DateTime())) { xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop: {0}", stop); }                      if (!t_stop.Equals(new DateTime()))
252                        {
253                            xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop: {0}", stop);
254                            xmltv_logger.Verbose.Debug.WriteLine("\tprogram_stop dt: {0}", t_stop.ToString());
255                        }
256                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStop, t_stop);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramStop, t_stop);
257    
258                      var channelid = node.Attribute(XMLTVConstants.Programs.ProgramChannelId);                      var channelid = node.Attribute(XMLTVConstants.Programs.ProgramChannelId);
# Line 237  namespace libxmltv.Core Line 263  namespace libxmltv.Core
263                      }                      }
264                                            
265                  }                  }
266                    node = null;
267              }              }
268          }          }
269          #endregion          #endregion
270            #region title
271          #region sub title          private class title : XMLTVBase<XMLTVProgram>
272            {
273                public title() : base(null, XMLTVConstants.Programs.ProgramTitle) { }
274                public title(XMLTVProgram instance, XElement node)
275                    : base(instance, XMLTVConstants.Programs.ProgramTitle)
276                {
277                    if (node == null) { throw new NullReferenceException("The node instance was null"); }
278                    if (node.Value != null)
279                    {
280                        instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramTitle, node.Value);
281                        xmltv_logger.Verbose.Debug.WriteLine("\tprogram_title: {0}", node.Value);
282                    }
283                    node = null;
284                }
285            }
286            #endregion
287            #region sub-title
288          private class subtitle : XMLTVBase<XMLTVProgram>          private class subtitle : XMLTVBase<XMLTVProgram>
289          {          {
290              public subtitle() : base(null, XMLTVConstants.Programs.ProgramSubTitle) { }              public subtitle() : base(null, XMLTVConstants.Programs.ProgramSubTitle) { }
# Line 254  namespace libxmltv.Core Line 297  namespace libxmltv.Core
297                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);
298                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);
299                  }                  }
300                    node = null;
301              }              }
302          }          }
303          #endregion          #endregion
304          #region sub title          #region description
305          private class description : XMLTVBase<XMLTVProgram>          private class description : XMLTVBase<XMLTVProgram>
306          {          {
307              public description() : base(null, XMLTVConstants.Programs.ProgramDescription) { }              public description() : base(null, XMLTVConstants.Programs.ProgramDescription) { }
# Line 270  namespace libxmltv.Core Line 314  namespace libxmltv.Core
314                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);
315                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);
316                  }                  }
317                    node = null;
318              }              }
319          }          }
320          #endregion          #endregion
321    
322            #region UnhandledExtraMetaData
323            private class UnhandledExtraProgramMetaData : XMLTVBase<XMLTVProgram>
324            {
325                public UnhandledExtraProgramMetaData() : base(null, null) { }
326                public UnhandledExtraProgramMetaData(XMLTVProgram instance, XElement node)
327                    : base(instance, null)
328                {
329                    if (node == null) { throw new NullReferenceException("The node instance was null"); }      
330                    xmltv_logger.Verbose.Debug.WriteLine("Parsng unhandled extra program meta-data: {0}", node.Name.ToString());
331                    if (this.GetInstance() != null)
332                    {
333                        List<IExtraMetaData> list = new List<IExtraMetaData>();
334                        if (!instance.MetaData.ContainsProperty(XMLTVConstants.Programs.ProgramExtraMetaData)) { instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramExtraMetaData, new List<ExtraMetaData>()); }
335                        else { list = (List<IExtraMetaData>)instance.MetaData[XMLTVConstants.Programs.ProgramExtraMetaData]; }
336                        ExtraMetaData data = new ExtraMetaData(node);
337                        list.Add(data);
338                        instance.MetaData[XMLTVConstants.Programs.ProgramExtraMetaData] = list;
339                        data = null;
340                    }
341                    node = null;
342                }
343            }      
344            #endregion
345          #endregion          #endregion
346      }      }
347  }  }

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

  ViewVC Help
Powered by ViewVC 1.1.22