-
Notifications
You must be signed in to change notification settings - Fork 365
/
NonRenderedParentElement.cs
63 lines (56 loc) · 2.57 KB
/
NonRenderedParentElement.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
//===============================================================================================================
// System : Sandcastle Tools - Sandcastle Tools Core Class Library
// File : NonRenderedParentElement.cs
// Author : Eric Woodruff (Eric@EWoodruff.us)
// Updated : 03/05/2022
// Note : Copyright 2022, Eric Woodruff, All rights reserved
//
// This file contains the class used to handle parent elements that do not themselves have any rendered
// representation.
//
// This code is published under the Microsoft Public License (Ms-PL). A copy of the license should be
// distributed with the code and can be found at the project website: https://GitHub.com/EWSoftware/SHFB. This
// notice, the author's name, and all copyright notices must remain intact in all applications, documentation,
// and source files.
//
// Date Who Comments
// ==============================================================================================================
// 01/14/2022 EFW Created the code
//===============================================================================================================
using System;
using System.Xml.Linq;
namespace Sandcastle.Core.PresentationStyle.Transformation.Elements
{
/// <summary>
/// This handles parent elements that do not themselves have any rendered representation. It simply parses
/// each of the child nodes in the given element if it has any and renders those as needed.
/// </summary>
public class NonRenderedParentElement : Element
{
#region Constructor
//=====================================================================
/// <summary>
/// Constructor
/// </summary>
/// <remarks>This element only contains child elements and has no title. If it contains a title
/// element, it will be ignored.</remarks>
/// <param name="name">The element name</param>
public NonRenderedParentElement(string name) : base(name)
{
}
#endregion
#region Methods
//=====================================================================
/// <inheritdoc />
public override void Render(TopicTransformationCore transformation, XElement element)
{
if(transformation == null)
throw new ArgumentNullException(nameof(transformation));
if(element == null)
throw new ArgumentNullException(nameof(element));
foreach(var child in element.Nodes())
transformation.RenderNode(child);
}
#endregion
}
}