/// <summary>
 /// Adds a new module that is statically referenced to the specified module info group.
 /// </summary>
 /// <param name="moduleInfoGroup">The group where to add the module info in.</param>
 /// <param name="moduleType">The type for the module. This type should be a descendant of <see cref="IModule"/>.</param>
 /// <param name="dependsOn">The names for the modules that this module depends on.</param>
 /// <returns>Returns the instance of the passed in module info group, to provide a fluid interface.</returns>
 /// <remarks>The name of the module will be the type name.</remarks>
 public static ModuleInfoGroup AddModule(
     this ModuleInfoGroup moduleInfoGroup,
     Type moduleType,
     int moduleIndex,
     params string[] dependsOn)
 {
     if (moduleType == null)
     {
         throw new ArgumentNullException("moduleType");
     }
     return(AddModule(moduleInfoGroup, moduleType.Name, moduleType, moduleIndex, dependsOn));
 }
        public virtual ModuleCatalog AddGroup(InitializationMode initializationMode, string refValue, params ModuleInfo[] moduleInfos)
        {
            if (moduleInfos == null)
            {
                throw new System.ArgumentNullException("moduleInfos");
            }

            ModuleInfoGroup newGroup = new ModuleInfoGroup();

            newGroup.InitializationMode = initializationMode;
            newGroup.Ref = refValue;

            foreach (ModuleInfo info in moduleInfos)
            {
                newGroup.Add(info);
            }

            this.items.Add(newGroup);

            return(this);
        }
        /// <summary>
        /// Adds a new module that is statically referenced to the specified module info group.
        /// </summary>
        /// <param name="moduleInfoGroup">The group where to add the module info in.</param>
        /// <param name="moduleName">The name for the module.</param>
        /// <param name="moduleType">The type for the module. This type should be a descendant of <see cref="IModule"/>.</param>
        /// <param name="dependsOn">The names for the modules that this module depends on.</param>
        /// <returns>Returns the instance of the passed in module info group, to provide a fluid interface.</returns>
        public static ModuleInfoGroup AddModule(
            this ModuleInfoGroup moduleInfoGroup,
            string moduleName,
            Type moduleType,
            int moduleIndex,
            params string[] dependsOn)
        {
            if (moduleType == null)
            {
                throw new ArgumentNullException("moduleType");
            }
            if (moduleInfoGroup == null)
            {
                throw new ArgumentNullException("moduleInfoGroup");
            }

            ModuleInfo moduleInfo = new ModuleInfo(moduleName, moduleType.AssemblyQualifiedName, moduleIndex);

            moduleInfo.DependsOn.AddRange(dependsOn);
            moduleInfoGroup.Add(moduleInfo);
            return(moduleInfoGroup);
        }