예제 #1
0
        public static ConfigObject ApplyJsonFromFileInfo(FileInfo file, ConfigObject config = null)
        {
            var     overlayJson   = File.ReadAllText(file.FullName);
            dynamic overlayConfig = ParseJson(overlayJson);

            return(Merger.Merge(overlayConfig, config));
        }
예제 #2
0
        // seeks a folder for .conf files
        public static ConfigObject ApplyFromDirectory(string path, ConfigObject config = null, bool recursive = false)
        {
            if (!Directory.Exists(path))
            {
                throw new Exception("no folder found in the given path");
            }

            if (config == null)
            {
                config = new ConfigObject();
            }

            DirectoryInfo info = new DirectoryInfo(path);

            if (recursive)
            {
                foreach (var dir in info.GetDirectories())
                {
                    Console.WriteLine("reading in folder {0}", dir);
                    config = ApplyFromDirectoryInfo(dir, config, true);
                }
            }

            // find all files
            var files = info.GetFiles();

            foreach (var file in files)
            {
                Console.WriteLine("reading in file {0}", file);
                config = ApplyJsonFromFileInfo(file, config);
            }
            return(config);
        }
예제 #3
0
        public static ConfigObject FromExpando(ExpandoObject e)
        {
            var edict = e as IDictionary <string, object>;
            var c     = new ConfigObject();
            var cdict = (IDictionary <string, object>)c;

            // this is not complete. It will, however work for ExpandoObjects
            // which consits only of primitive types, ExpandoObject or ExpandoObject []
            // but won't work for generic ExpandoObjects which might include collections etc.
            foreach (var kvp in edict)
            {
                // recursively convert and add ExpandoObjects
                if (kvp.Value is ExpandoObject)
                {
                    cdict.Add(kvp.Key, FromExpando((ExpandoObject)kvp.Value));
                }
                else if (kvp.Value is ExpandoObject[])
                {
                    var configObjects = new List <ConfigObject>();
                    foreach (var ex in ((ExpandoObject[])kvp.Value))
                    {
                        configObjects.Add(FromExpando(ex));
                    }
                    cdict.Add(kvp.Key, configObjects.ToArray());
                }
                else
                {
                    cdict.Add(kvp.Key, kvp.Value);
                }
            }
            return(c);
        }
예제 #4
0
        public void ApplyJson(string json)
        {
            ConfigObject result = Config.ApplyJson(json, this);

            // replace myself's members with the new ones
            Members = result.Members;
        }
예제 #5
0
        public static ConfigObject ApplyJson(string json, ConfigObject config = null)
        {
            if (config == null)
            {
                config = new ConfigObject();
            }

            dynamic parsed = ParseJson(json);

            return(Merger.Merge(parsed, config));
        }
예제 #6
0
        public static void SetUserConfig(ConfigObject config)
        {
            User = config;
            // disable the watcher
            if (_userConfigWatcher != null)
            {
                _userConfigWatcher.EnableRaisingEvents = false;
                _userConfigWatcher.Dispose();
                _userConfigWatcher = null;
            }

            // invalidate the Global config, forcing a re-merge next time its accessed
            _globalConfig = null;
        }
예제 #7
0
        public static ConfigObject ParseJson(string json)
        {
            var lines = json.Split(new char[] { '\n' });
            // remove lines that start with a dash # character
            var filtered = from l in lines
                           where !(Regex.IsMatch(l, @"^\s*#(.*)"))
                           select l;

            var filteredJson = string.Join("\n", filtered);

            //var json_reader = new JsonReader ();
            //dynamic parsed = JObject.Parse(filtered_json);
            dynamic parsed = JsonConvert.DeserializeObject <ExpandoObject>(filteredJson);
            // convert the ExpandoObject to ConfigObject before returning
            var result = ConfigObject.FromExpando(parsed);

            return(result);
        }
예제 #8
0
 public static ConfigObject ApplyFromDirectoryInfo(DirectoryInfo info, ConfigObject config = null, bool recursive = false)
 {
     return(ApplyFromDirectory(info.FullName, config, recursive));
 }
예제 #9
0
 public static ConfigObject ApplyJsonFromPath(string path, ConfigObject config = null)
 {
     return(ApplyJsonFromFileInfo(new FileInfo(path), config));
 }
예제 #10
0
        /// <summary>
        /// Merge the specified obj2 and obj1, where obj1 has precendence and
        /// overrules obj2 if necessary.
        /// </summary>
        /// <exception cref='TypeMissmatchException'>
        /// Is thrown when the type missmatch exception.
        /// </exception>
        public static dynamic Merge(dynamic mObj1, dynamic mObj2)
        {
            dynamic obj1 = mObj1;
            dynamic obj2 = mObj2;

            // make sure we only deal with ConfigObject but not ExpandoObject as currently
            // return from JsonFX
            if (obj1 is ExpandoObject)
            {
                obj1 = ConfigObject.FromExpando(obj1);
            }
            if (obj2 is ExpandoObject)
            {
                obj2 = ConfigObject.FromExpando(obj2);
            }

            // if both objects are NullExceptionPreventer, return a ConfigObject so the
            // user gets an "Empty" ConfigObject
            if (obj1 is NullExceptionPreventer && obj2 is NullExceptionPreventer)
            {
                return(new ConfigObject());
            }

            // if any object is of NullExceptionPreventer, the other object gets precedence / overruling
            if (obj1 is NullExceptionPreventer && obj2 is ConfigObject)
            {
                return(obj2);
            }
            if (obj2 is NullExceptionPreventer && obj1 is ConfigObject)
            {
                return(obj1);
            }

            // handle what happens if one of the args is null
            if (obj1 == null && obj2 == null)
            {
                return(new ConfigObject());
            }

            if (obj2 == null)
            {
                return(obj1);
            }
            if (obj1 == null)
            {
                return(obj2);
            }

            if (obj1.GetType() != obj2.GetType())
            {
                throw new TypeMissmatchException();
            }

            // changes in the dictionary WILL REFLECT back to the object
            var dict1 = (IDictionary <string, object>)(obj1);
            var dict2 = (IDictionary <string, object>)(obj2);

            dynamic result = new ConfigObject();
            var     rdict  = (IDictionary <string, object>)result;

            // first, copy all non colliding keys over
            foreach (var kvp in dict1)
            {
                if (!dict2.Keys.Contains(kvp.Key))
                {
                    rdict.Add(kvp.Key, kvp.Value);
                }
            }
            foreach (var kvp in dict2)
            {
                if (!dict1.Keys.Contains(kvp.Key))
                {
                    rdict.Add(kvp.Key, kvp.Value);
                }
            }

            // now handle the colliding keys
            foreach (var kvp1 in dict1)
            {
                // skip already copied over keys
                if (!dict2.Keys.Contains(kvp1.Key) || dict2[kvp1.Key] == null)
                {
                    continue;
                }

                var kvp2 = new KeyValuePair <string, object>(kvp1.Key, dict2[kvp1.Key]);

                // some shortcut variables to make code more readable
                var key    = kvp1.Key;
                var value1 = kvp1.Value;
                var value2 = kvp2.Value;
                var type1  = value1.GetType();
                var type2  = value1.GetType();

                // check if both are same type
                if (type1 != type2)
                {
                    throw new TypeMissmatchException();
                }

                if (value1 is ConfigObject[])
                {
                    rdict[key] = CollectionMerge(value1, value2);

                    /*var d1 = val1 as IDictionary<string, object>;
                     *                  var d2 = val2 as IDictionary<string, object>;
                     *                  rdict[key] = CollectionMerge (val1, val2); */
                }
                else if (value1 is ConfigObject)
                {
                    rdict[key] = Merge(value1, value2);
                }
                else if (value1 is string)
                {
                    rdict[key] = value1;
                }
                else if (value1 is IEnumerable)
                {
                    rdict[key] = CollectionMerge(value1, value2);
                }
                else
                {
                    rdict[key] = value1;
                }

                //else if (kvp.Value.GetType ().IsByRef) {
                // recursively merge it
                //}
            }
            return(result);
        }