Add LINQPad script to convert old XML to markdown
This commit is contained in:
parent
b234ad21dd
commit
4b30a61940
|
@ -0,0 +1,82 @@
|
|||
<Query Kind="Statements">
|
||||
<Reference><RuntimeDirectory>\System.Web.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.Configuration.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.DirectoryServices.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.EnterpriseServices.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.Web.RegularExpressions.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.Design.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.Web.ApplicationServices.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.ComponentModel.DataAnnotations.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.DirectoryServices.Protocols.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.Security.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.Runtime.Caching.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.ServiceProcess.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.Web.Services.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\Microsoft.Build.Utilities.v4.0.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\Microsoft.Build.Framework.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\Microsoft.Build.Tasks.v4.0.dll</Reference>
|
||||
<Reference><RuntimeDirectory>\System.Windows.Forms.dll</Reference>
|
||||
</Query>
|
||||
|
||||
var xmlPath = @"C:\Users\James\Projects\Standalone\LogParserPlus\LogParserPlus.Web\App_Data\functions.xml";
|
||||
var mdPath = @"C:\Users\James\Projects\logparserplus.com\content\functions\";
|
||||
|
||||
var xmlItems = XDocument.Load(xmlPath).Descendants("function");
|
||||
|
||||
var filePath = "";
|
||||
foreach (var xmlItem in xmlItems)
|
||||
{
|
||||
filePath = mdPath + xmlItem.Element("name").Value.ToLower() + ".md";
|
||||
|
||||
if (File.Exists(filePath))
|
||||
{
|
||||
File.Delete(filePath);
|
||||
}
|
||||
|
||||
var fileData = new StringBuilder();
|
||||
fileData.AppendLine("+++");
|
||||
fileData.AppendFormat("name = \"{0}\"" + Environment.NewLine, xmlItem.Element("name").Value);
|
||||
var syntaxRaw = System.Web.HttpUtility.HtmlDecode(xmlItem.Element("syntax").Value);
|
||||
fileData.AppendFormat("syntax = \"{0}\"" + Environment.NewLine, syntaxRaw);
|
||||
fileData.AppendFormat("description = \"{0}\"" + Environment.NewLine, xmlItem.Element("description").Value);
|
||||
fileData.AppendFormat("type = \"{0}\"" + Environment.NewLine, xmlItem.Element("type").Value);
|
||||
|
||||
// Related.
|
||||
var relatedItems = xmlItem.Elements("related").Select(e => e.Value).Where(e => !string.IsNullOrWhiteSpace(e));
|
||||
if (relatedItems.Any())
|
||||
{
|
||||
fileData.AppendFormat("related = [\"{0}\"]" + Environment.NewLine, string.Join("\", \"", relatedItems));
|
||||
}
|
||||
|
||||
//fileData.AppendFormat(" = \"{0}\"" + Environment.NewLine, xmlItem.Element("").Value);
|
||||
fileData.AppendLine("+++");
|
||||
fileData.AppendLine("");
|
||||
|
||||
var examples = xmlItem.Element("examples").Descendants().Where(e => !string.IsNullOrWhiteSpace(e.Value));
|
||||
if (examples.Any())
|
||||
{
|
||||
examples.Dump();
|
||||
fileData.AppendLine("#### Examples");
|
||||
foreach (var example in examples)
|
||||
{
|
||||
fileData.AppendFormat("- {0}{1}"
|
||||
, example.Value
|
||||
.Replace("<span>", "`")
|
||||
.Replace("</span>", "` " + Environment.NewLine + " ")
|
||||
, Environment.NewLine);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// Examples.
|
||||
|
||||
|
||||
fileData.ToString().Dump();
|
||||
File.WriteAllText(filePath, fileData.ToString());
|
||||
}
|
||||
|
||||
|
||||
|
||||
xmlItems.Dump();
|
||||
|
||||
|
Loading…
Reference in New Issue