Newer
Older
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
namespace MasterDevs.ChromeDevTools.ProtocolGenerator
{
public class ProtocolProcessor
{
public static void ResolveTypeReferences(Protocol protocol, Dictionary<string, string> explicitMappings)
ResolveTypeReferences(protocol, domain, explicitMappings);
public static void ResolveTypeReferences(Protocol protocol, Domain domain, Dictionary<string, string> explicitMappings)
ResolveTypeReferences(protocol, domain, command, explicitMappings);
public static void ResolveTypeReferences(Protocol protocol, Domain domain, Command command, Dictionary<string, string> explicitMappings)
{
foreach (var parameter in command.Parameters)
{
ResolveTypeReferences(protocol, domain, parameter, explicitMappings);
}
foreach (var returnValue in command.Returns)
{
ResolveTypeReferences(protocol, domain, returnValue, explicitMappings);
public static void ResolveTypeReferences(Protocol protocol, Domain domain, Type property, Dictionary<string, string> explicitMappings)
{
if (property.TypeReference != null)
{
// Find the type which is being referenced
var referenceParts = property.TypeReference.Split(new char[] { '.' }, StringSplitOptions.RemoveEmptyEntries);
Domain referencedDomain = null;
Type referencedType = null;
if (referenceParts.Length == 1)
{
referencedDomain = domain;
referencedType = domain.GetType(referenceParts[0]);
}
else if (referenceParts.Length == 2)
{
referencedDomain = protocol.GetDomain(referenceParts[0]);
referencedType = referencedDomain.GetType(referenceParts[1]);
}
else
{
throw new ArgumentOutOfRangeException();
}
string fullReferenceName = $"{referencedDomain.Name}.{referencedType.Name}";
{
property.Kind = "string";
property.TypeReference = null;
}
else if (referencedType.IsInteger())
{
property.Kind = "integer";
property.TypeReference = null;
}
else if (explicitMappings.ContainsKey(fullReferenceName))
{
property.TypeReference = explicitMappings[fullReferenceName];
}
}
{
ResolveTypeReferences(protocol, domain, property.Items, explicitMappings);
public static Protocol LoadProtocol(string[] paths, string alias)
if (paths == null || paths.Length < 1)
throw new ArgumentException("Must specify at least one path", nameof(paths));
JsonSerializerSettings settings = new JsonSerializerSettings
{
MissingMemberHandling = MissingMemberHandling.Error,
MetadataPropertyHandling = MetadataPropertyHandling.Ignore
};
string json = File.ReadAllText(paths[0]);
Protocol p = JsonConvert.DeserializeObject<Protocol>(json, settings);
if (paths.Length > 1)
{
foreach (var path in paths.Skip(1))
{
json = File.ReadAllText(path);
Protocol partial = JsonConvert.DeserializeObject<Protocol>(json, settings);
foreach (var domain in partial.Domains)
p.Domains.Add(domain);
}
}
foreach (var domain in p.Domains)
{
foreach (var command in domain.Commands)
{
command.SupportedBy.Add(alias);
}
foreach (var @event in domain.Events)
{
@event.SupportedBy.Add(alias);
}
foreach (var type in domain.Types)
{
type.SupportedBy.Add(alias);
}
}
return p;
}
}
}