/[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 97 by william, Sun Mar 10 09:43:49 2013 UTC revision 111 by william, Sun Mar 10 15:37:16 2013 UTC
# Line 63  namespace libxmltv.Core Line 63  namespace libxmltv.Core
63          {          {
64              return string.Format("{0}: {1} - {2} ({3}) ['{4}' <==> '{5}']",              return string.Format("{0}: {1} - {2} ({3}) ['{4}' <==> '{5}']",
65                  MetaData["Id"].ToString(),                  MetaData["Id"].ToString(),
66                   MetaData[(XMLTVConstants.Programs.ProgramTitle)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramTitle].ToString(),
67                   MetaData[(XMLTVConstants.Programs.ProgramSubTitle)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramSubTitle].ToString(),
68                   MetaData[(XMLTVConstants.Programs.ProgramChannelId)].ToString(),                   MetaData[XMLTVConstants.Programs.ProgramChannelId].ToString(),
69                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStart]).ToString("yyyy/MM/dd hh:mm tt"),                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStart]).ToString("yyyy/MM/dd hh:mm tt"),
70                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStop]).ToString("yyyy/MM/dd hh:mm tt"));                  ((DateTime)MetaData[XMLTVConstants.Programs.ProgramStop]).ToString("yyyy/MM/dd hh:mm tt"));
71          }          }
# Line 161  namespace libxmltv.Core Line 161  namespace libxmltv.Core
161                              var ctors = type.GetConstructors(flags);                              var ctors = type.GetConstructors(flags);
162                              bool has_default_ctor = false;                              bool has_default_ctor = false;
163                              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; } }
164                                ctors = null;
165                              if (!has_default_ctor) { continue; }                              if (!has_default_ctor) { continue; }
166                              raw_instance = Activator.CreateInstance(type, flags, null, new object[0], culture);                              raw_instance = Activator.CreateInstance(type, flags, null, new object[0], culture);
167                              if (raw_instance != null)                              if (raw_instance != null)
# Line 169  namespace libxmltv.Core Line 170  namespace libxmltv.Core
170                                  if (handler_value != null && handler_value.ToString() == node.Name.ToString())                                  if (handler_value != null && handler_value.ToString() == node.Name.ToString())
171                                  {                                  {
172                                      handler_type = type;                                      handler_type = type;
173                                        handler_value = null;
174                                        raw_instance = null;
175                                        handler_prop = null;
176                                        iface = null;
177                                      break;                                      break;
178                                  }                                  }
179                                    handler_value = null;
180                              }                              }
181                                raw_instance = null;
182                          }                          }
183                            handler_prop = null;
184                      }                      }
185                        iface = null;
186                  }                  }
187              }              }
188                t = null;
189                asm = null;
190                types = null;
191                classes = null;
192              if (handler_type == null)              if (handler_type == null)
193              {              {
194                  StringBuilder node_builder = new StringBuilder();                  try
195                  node_builder.AppendFormat("<{0} ", node.Name);                  {
196                  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);
197                  string node_text = string.Format("{0}>", node_builder.ToString().TrimEnd(new char[] { ' ' }));                  }
198                  xmltv_logger.Verbose.Warn.WriteLine("Ignoring unhandled extra meta-data: {0}", node_text);                  catch (Exception ex) { throw ex; }
199    
200                    if (raw_instance == null)
201                    {
202                        StringBuilder node_builder = new StringBuilder();
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); } }
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);
207                    }
208              }              }
209              else              else
210              {              {
211                  raw_instance = Activator.CreateInstance(handler_type, flags, null, new object[] { this, node }, culture);                  try
212                    {
213                        raw_instance = Activator.CreateInstance(handler_type, flags, null, new object[] { this, node }, culture);
214                    }
215                    catch (Exception ex) { throw ex; }
216              }              }
217                raw_instance = null;
218                flags = 0;
219                culture = null;
220                node = null;
221          }          }
222    
223    
224    
225          #region sub-classes          #region sub-classes      
226          #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)  
227          private class programme : XMLTVBase<XMLTVProgram>          private class programme : XMLTVBase<XMLTVProgram>
228          {          {
229              public programme() : base(null, XMLTVConstants.Programs.RootElement) { }              public programme() : base(null, XMLTVConstants.Programs.RootElement) { }
# Line 237  namespace libxmltv.Core Line 251  namespace libxmltv.Core
251                      }                      }
252                                            
253                  }                  }
254                    node = null;
255              }              }
256          }          }
257          #endregion          #endregion
258            #region title
259          #region sub title          private class title : XMLTVBase<XMLTVProgram>
260            {
261                public title() : base(null, XMLTVConstants.Programs.ProgramTitle) { }
262                public title(XMLTVProgram instance, XElement node)
263                    : base(instance, XMLTVConstants.Programs.ProgramTitle)
264                {
265                    if (node == null) { throw new NullReferenceException("The node instance was null"); }
266                    if (node.Value != null)
267                    {
268                        instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramTitle, node.Value);
269                        xmltv_logger.Verbose.Debug.WriteLine("\tprogram_title: {0}", node.Value);
270                    }
271                    node = null;
272                }
273            }
274            #endregion
275            #region sub-title
276          private class subtitle : XMLTVBase<XMLTVProgram>          private class subtitle : XMLTVBase<XMLTVProgram>
277          {          {
278              public subtitle() : base(null, XMLTVConstants.Programs.ProgramSubTitle) { }              public subtitle() : base(null, XMLTVConstants.Programs.ProgramSubTitle) { }
# Line 254  namespace libxmltv.Core Line 285  namespace libxmltv.Core
285                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramSubTitle, node.Value);
286                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_subtitle: {0}", node.Value);
287                  }                  }
288                    node = null;
289              }              }
290          }          }
291          #endregion          #endregion
292          #region sub title          #region description
293          private class description : XMLTVBase<XMLTVProgram>          private class description : XMLTVBase<XMLTVProgram>
294          {          {
295              public description() : base(null, XMLTVConstants.Programs.ProgramDescription) { }              public description() : base(null, XMLTVConstants.Programs.ProgramDescription) { }
# Line 270  namespace libxmltv.Core Line 302  namespace libxmltv.Core
302                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);                      instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramDescription, node.Value);
303                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);                      xmltv_logger.Verbose.Debug.WriteLine("\tprogram_description: {0}", node.Value);
304                  }                  }
305                    node = null;
306              }              }
307          }          }
308          #endregion          #endregion
309    
310            #region UnhandledExtraMetaData
311            private class UnhandledExtraProgramMetaData : XMLTVBase<XMLTVProgram>
312            {
313                public UnhandledExtraProgramMetaData() : base(null, null) { }
314                public UnhandledExtraProgramMetaData(XMLTVProgram instance, XElement node)
315                    : base(instance, null)
316                {
317                    if (node == null) { throw new NullReferenceException("The node instance was null"); }      
318                    xmltv_logger.Verbose.Debug.WriteLine("Parsng unhandled extra program meta-data: {0}", node.Name.ToString());
319                    if (this.GetInstance() != null)
320                    {
321                        List<IExtraMetaData> list = new List<IExtraMetaData>();
322                        if (!instance.MetaData.ContainsProperty(XMLTVConstants.Programs.ProgramExtraMetaData)) { instance.MetaData.AddProperty(XMLTVConstants.Programs.ProgramExtraMetaData, new List<ExtraMetaData>()); }
323                        else { list = (List<IExtraMetaData>)instance.MetaData[XMLTVConstants.Programs.ProgramExtraMetaData]; }
324                        ExtraMetaData data = new ExtraMetaData(node);
325                        list.Add(data);
326                        instance.MetaData[XMLTVConstants.Programs.ProgramExtraMetaData] = list;
327                        data = null;
328                    }
329                    node = null;
330                }
331            }      
332            #endregion
333          #endregion          #endregion
334      }      }
335  }  }

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

  ViewVC Help
Powered by ViewVC 1.1.22