コード例 #1
0
        /// <summary>
        /// Given a message, find corresponding command and run it.
        /// </summary>
        /// <param name="msg">The message that ran the command.</param>
        /// <param name="input">The input from the user.</param>
        public bool ExecuteUserInput(Matbot.Client.Message msg, ParsedInput p)
        {
            if (p == null)
            {
                return(false);
            }

            if (msg.User.BotRank == Client.UserRank.Gali)
            {
                bool c = true;
                if (p.Name != null)
                {
                    if (p.Name.Equals("register"))
                    {
                        c = false;
                    }
                }
                if (c)
                {
                    msg.Reply(p.RawInput);
                    return(true);
                }
            }

            if (p.IsCommand)
            {
                if (!Commands.ContainsKey(p.Name.ToLower()))
                {
                    return(false);
                }
                Command c = Commands[p.Name.ToLower()];
                if (c != null)
                {
                    c.ReformatInput(p);

                    List <object> parameters;
                    try
                    {
                        CmdVariation v = c.FindCommandVariationByParsedInput(p, out parameters);

                        c.ExecuteVariation(v, msg, parameters.ToArray());
                    }
                    catch (CorrectVariationNotFoundException ex)
                    {
                        msg.Reply(ex.Message);
                        return(false);
                    }
                }
                else
                {
                    return(false);
                }
            }
            else
            {
                return(false);
            }

            return(true);
        }
コード例 #2
0
ファイル: Command.cs プロジェクト: MatanRad/Matbot
        /// <summary>
        /// Returns a string detailing each variation and their respective description.
        /// </summary>
        public string ToStringDetailed()
        {
            string msg = this.ToString();

            bool printedHeader = false;

            for (int i = 0; i < Variations.Length; i++)
            {
                CmdVariation v = Variations[i];

                if (v.Description != null)
                {
                    if (!v.Description.Equals(""))
                    {
                        if (!printedHeader)
                        {
                            printedHeader = true;
                            msg          += "Descriptions:";
                        }

                        msg += "\n[" + i + "] " + v.Description;
                    }
                }
            }

            return(msg);
        }
コード例 #3
0
ファイル: Command.cs プロジェクト: MatanRad/Matbot
        /// <summary>
        /// Iterates over all this class' methods, finds and coverts fitting methods to variations.
        /// </summary>
        /// <returns>Array of converted variations.</returns>
        private CmdVariation[] InitVariations()
        {
            MethodInfo[] allmethods = this.GetType().GetMethods(Command.bindingFlags);
            int          count      = 0;

            foreach (MethodInfo i in allmethods)
            {
                if (i.Name.Equals(executeMethodName) && i.GetParameters().Length >= Command.InitialTypes.Length)
                {
                    bool increase = true;
                    for (int j = 0; j < Command.InitialTypes.Length; j++)
                    {
                        Type t = i.GetParameters()[j].ParameterType;
                        if (!t.Equals(InitialTypes[j]))
                        {
                            increase = false;
                            break;
                        }
                    }
                    if (increase)
                    {
                        count++;
                    }
                }
            }

            CmdVariation[] vars = new CmdVariation[count];

            int ind = 0;

            for (int i = 0; i < allmethods.Length; i++)
            {
                if (allmethods[i].Name.Equals(executeMethodName) && allmethods[i].GetParameters().Length >= Command.InitialTypes.Length)
                {
                    ParameterInfo[] parameters = allmethods[i].GetParameters();

                    bool insert = true;
                    for (int j = 0; j < Command.InitialTypes.Length; j++)
                    {
                        Type t = parameters[j].ParameterType;
                        if (!t.Equals(InitialTypes[j]))
                        {
                            insert = false;
                            break;
                        }
                    }
                    if (insert)
                    {
                        vars[ind] = new CmdVariation(this.Name, FilterOutMethodParameters <ParameterInfo>(parameters));
                        ind++;
                    }
                }
            }

            return(vars);
        }
コード例 #4
0
ファイル: Command.cs プロジェクト: MatanRad/Matbot
        /// <summary>
        /// Find a variation using MethodInfo.
        /// </summary>
        protected CmdVariation FindVariationByMethodInfo(MethodInfo method)
        {
            List <CmdVariation> conflicting = new List <CmdVariation>();
            CmdVariation        v           = null;

            if (!method.Name.Equals(Command.executeMethodName))
            {
                throw new InvalidVariationMethodException(method);
            }

            foreach (CmdVariation i in Variations)
            {
                bool failed = false;

                ParameterInfo[] filtered = FilterOutMethodParameters <ParameterInfo>(method.GetParameters());
                if (i.Attributes.Count != filtered.Length)
                {
                    continue;
                }

                for (int j = 0; j < i.Attributes.Count; j++)
                {
                    if (!(i.Attributes[j].AType.Equals(filtered[j].GetType()) &&
                          i.Attributes[j].Optional == filtered[j].IsOptional &&
                          i.Attributes[j].ParamName.Equals(filtered[j].Name)))
                    {
                        failed = true;
                        break;
                    }
                }

                if (!failed)
                {
                    conflicting.Add(i);
                    v = i;
                }
            }

            if (conflicting.Count == 0)
            {
                throw new InvalidVariationMethodException(method);
            }
            if (conflicting.Count > 1)
            {
                throw new ConflictingVariationsException(this.Name, conflicting.ToArray(), "", method);
            }

            return(v);
        }
コード例 #5
0
ファイル: Command.cs プロジェクト: MatanRad/Matbot
        public void ExecuteVariation(CmdVariation v, Message msg, object[] parameters)
        {
            MethodInfo m = this.GetType().GetMethod(Command.executeMethodName, Command.bindingFlags, null, v.GetMethodAttributeTypes(), null);

            object[] n = new object[parameters.Length + Command.InitialTypes.Length];
            n[0] = msg;
            parameters.CopyTo(n, Command.InitialTypes.Length);

            if (msg.User.BotRank < RequiredRank && HasRequiredRank)
            {
                msg.Reply(this.GetNoPermissionMessage(msg));
            }
            else
            {
                m.Invoke(this, n);
            }
        }
コード例 #6
0
ファイル: Command.cs プロジェクト: MatanRad/Matbot
        /// <summary>
        /// Calculates priority of variation.
        /// </summary>
        public int CalculateVarPriority(CmdVariation v)
        {
            var keys = this.paramTypePriorities.Keys;

            int priority = 0;

            foreach (CmdAttribute a in v.Attributes)
            {
                if (!keys.Contains(a.AType))
                {
                    priority += defaultTypePriority;
                }
                else
                {
                    priority += paramTypePriorities[a.AType];
                }
            }

            return(priority);
        }
コード例 #7
0
ファイル: Command.cs プロジェクト: MatanRad/Matbot
        /// <summary>
        /// Add description for a command variation.
        /// </summary>
        /// <param name="method">MethodInfo for the variation's method.</param>
        /// <param name="desc">Variation description.</param>
        /// <param name="names">Array of names for each command parameter</param>
        protected void AddCmdVariationDesc(MethodInfo method, string desc, string[] names = null)
        {
            CmdVariation v = FindVariationByMethodInfo(method);

            v.Description = desc;

            if (names != null)
            {
                if (names.Length == 0)
                {
                    return;
                }
                if (names.Length != v.Attributes.Count)
                {
                    throw new InvalidVariationNameCountException(v, names.Length);
                }
                for (int i = 0; i < names.Length; i++)
                {
                    v.Attributes[i].Name = names[i];
                }
            }
        }
コード例 #8
0
ファイル: Command.cs プロジェクト: MatanRad/Matbot
        /// <summary>
        /// Try to find a single CmdVariation from a user's ParsedInput
        /// </summary>
        public CmdVariation FindCommandVariationByParsedInput(ParsedInput input, out List <object> converted)
        {
            CmdVariation[] vars            = Variations;
            var            convertedPerVar = new List <List <object> >();

            converted = new List <object>();
            List <CmdVariation> conflicts = new List <CmdVariation>();

            string[] param = input.Parameters;

            foreach (CmdVariation v in vars)
            {
                if (v == null)
                {
                    continue;
                }
                if (v.Attributes.Count != param.Length)
                {
                    continue;
                }
                bool failed       = false;
                var  convertedVar = new List <object>();
                convertedPerVar.Add(convertedVar);

                for (int i = 0; i < v.Attributes.Count; i++)
                {
                    CmdAttribute a = v.Attributes[i];
                    try
                    {
                        object t = ClassConverter.ConvertToObj(param[i], a.AType);
                        convertedVar.Add(t);
                    }
                    catch (Exception e)
                    {
                        if (e is InvalidCastException || e is FormatException)
                        {
                            System.Diagnostics.Debug.WriteLine(e.GetType().Name);
                            failed = true;
                            convertedPerVar.RemoveAt(convertedPerVar.Count - 1);
                            break;
                        }
                        else
                        {
                            throw e;
                        }
                    }
                }

                if (!failed)
                {
                    conflicts.Add(v);
                }
            }

            if (conflicts.Count == 0)
            {
                throw new CorrectVariationNotFoundException(input);
            }
            if (conflicts.Count > 1)
            {
                bool throwError = true;
                if (this.paramTypePriorities != null)
                {
                    CmdVariation resolve = ResolveConflictViaPriority(conflicts);
                    if (resolve != null)
                    {
                        throwError = false;
                        converted  = convertedPerVar[conflicts.IndexOf(resolve)];
                        return(resolve);
                    }
                }

                if (throwError)
                {
                    throw new ConflictingVariationsException(input.Name, conflicts.ToArray(), input.RawInput, null);
                }
            }

            // Case where only 1 variation succeeds
            converted = convertedPerVar[0];
            return(conflicts[0]);
        }