public override SymInfo[] GetNamesAsInObject(ExpressionVisitor ev) { List<SymInfo> syms = new List<SymInfo>(); if (!CodeCompletionController.CurrentParser.LanguageInformation.IncludeDotNetEntities) return syms.ToArray(); MemberInfo[] mis = ctn.GetMembers(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.FlattenHierarchy); List<MemberInfo> members = new List<MemberInfo>(); members.AddRange(mis); IEnumerable<MemberInfo> en = PascalABCCompiler.NetHelper.NetHelper.GetExtensionMethods(ctn); members.AddRange(en); mis = members.ToArray(); if (ctn.IsInterface) { List<MemberInfo> mems = new List<MemberInfo>(); mems.AddRange(mis); mems.AddRange(typeof(object).GetMembers(BindingFlags.Public | BindingFlags.Instance)); Type[] types = ctn.GetInterfaces(); foreach (Type t in types) mems.AddRange(t.GetMembers(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.FlattenHierarchy)); mis = mems.ToArray(); } foreach (MemberInfo mi in mis) if (!mi.Name.Contains("$")) switch (mi.MemberType) { case MemberTypes.Method: if (!(mi as MethodInfo).IsSpecialName) { SymInfo si2 = new SymInfo(null, SymbolKind.Method, null); si2 = new CompiledMethodScope(si2, mi as MethodInfo, this).si; if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } break; case MemberTypes.Field: { if (!(mi as FieldInfo).IsSpecialName) { SymInfo si2 = new SymInfo(null, SymbolKind.Field, null); if ((mi as FieldInfo).IsLiteral) si2.kind = SymbolKind.Constant; si2 = new CompiledFieldScope(si2, mi as FieldInfo, this).si; if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } } break; case MemberTypes.Property: { SymInfo si2 = new SymInfo(null, SymbolKind.Property, null); si2 = new CompiledPropertyScope(si2, mi as PropertyInfo, this).si; if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } break; case MemberTypes.Event: { SymInfo si2 = new SymInfo(null, SymbolKind.Event, null); si2 = new CompiledEventScope(si2, mi as EventInfo, this).si; if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } break; } if (implemented_interfaces != null && false) { foreach (TypeScope ts in implemented_interfaces) syms.AddRange(ts.GetNamesAsInObject(ev)); } return syms.ToArray(); }
public override SymInfo[] GetNames(ExpressionVisitor ev, PascalABCCompiler.Parsers.KeywordKind keyword, bool called_in_base) { List<SymInfo> syms = new List<SymInfo>(); if (!CodeCompletionController.CurrentParser.LanguageInformation.IncludeDotNetEntities) return syms.ToArray(); MemberInfo[] mis = ctn.GetMembers(BindingFlags.Public | BindingFlags.NonPublic |/*BindingFlags.Instance|*/BindingFlags.Static | BindingFlags.FlattenHierarchy); List<MemberInfo> constrs = new List<MemberInfo>(); //constrs.AddRange(ctn.GetNestedTypes(BindingFlags.Public)); //if (ctn != typeof(object)) ConstructorInfo[] cis = ctn.GetConstructors(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic); foreach (ConstructorInfo ci in cis) if (!called_in_base) constrs.Add(ci); else if (ci.GetParameters().Length > 0) constrs.Add(ci); constrs.AddRange(mis); //constrs.AddRange(PascalABCCompiler.NetHelper.NetHelper.GetExtensionMethods(ctn)); mis = constrs.ToArray(); if (ctn.IsInterface) { return syms.ToArray(); } foreach (MemberInfo mi in mis) if (!mi.Name.Contains("$")) switch (mi.MemberType) { case MemberTypes.Method: if (!(mi as MethodInfo).IsSpecialName && (mi as MethodInfo).IsStatic) { SymInfo si2 = new SymInfo(null, SymbolKind.Method, null); CompiledMethodScope member = new CompiledMethodScope(si2, mi as MethodInfo, this); si2 = member.si; if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } break; case MemberTypes.Field: { if (!(mi as FieldInfo).IsSpecialName && (mi as FieldInfo).IsStatic) { SymInfo si2 = new SymInfo(null, SymbolKind.Field, null); if ((mi as FieldInfo).IsLiteral) si2.kind = SymbolKind.Constant; si2 = new CompiledFieldScope(si2, mi as FieldInfo, this).si; if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } } break; case MemberTypes.Constructor: { SymInfo si2 = new SymInfo(null, SymbolKind.Method, null); CompiledConstructorScope member = new CompiledConstructorScope(si2, mi as ConstructorInfo, this); si2 = member.si; if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } break; case MemberTypes.Property: { PropertyInfo pi = mi as PropertyInfo; if (pi.GetGetMethod(true) != null && pi.GetGetMethod(true).IsStatic) { SymInfo si2 = new SymInfo(null, SymbolKind.Property, null); si2 = new CompiledPropertyScope(si2, mi as PropertyInfo, this).si; if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } } break; case MemberTypes.Event: { MethodInfo acc_mi = (mi as EventInfo).GetAddMethod(true); if (acc_mi != null && acc_mi.IsStatic) { SymInfo si2 = new SymInfo(null, SymbolKind.Event, null); si2 = new CompiledEventScope(si2, mi as EventInfo, this).si; syms.Add(si2); if (si2.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) syms.Add(si2); } else if (si2.acc_mod != access_modifer.private_modifer && si2.acc_mod != access_modifer.internal_modifer) syms.Add(si2); } } break; case MemberTypes.NestedType: { if ((mi as Type).IsNestedPublic) { SymInfo si2 = new SymInfo(null, SymbolKind.Type, null); CompiledScope member = TypeTable.get_compiled_type(si2, mi as Type); si2 = member.si; syms.Add(si2); } } break; } return syms.ToArray(); }
//poluchit vse imena kak po tochke iz objektnoj peremennoj, sootv. ekzemplarnye chleny klassa i nadklassov public override SymInfo[] GetNamesAsInObject(ExpressionVisitor ev) { //if (original_type != null) // return original_type.GetNamesAsInObject(ev); List<SymInfo> lst = new List<SymInfo>(); foreach (SymScope ss in members) { if (ss is ProcScope && (ss as ProcScope).IsConstructor()) continue; if (!ss.si.name.StartsWith("$") && !ss.is_static && !(ss is TemplateParameterScope)) { if (ss.si.acc_mod == access_modifer.private_modifer) { if (ev.CheckPrivateForBaseAccess(ev.entry_scope, this)) lst.Add(ss.si); } else if (ss.si.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) lst.Add(ss.si); } else lst.Add(ss.si); if (!ss.si.has_doc) UnitDocCache.AddDescribeToComplete(ss); } } if (this.documentation != null && this.documentation.Contains("!#") && baseScope is CompiledScope) return lst.ToArray(); if (baseScope != null) { lst.AddRange(baseScope.GetNamesAsInObject(ev)); } if (implemented_interfaces != null && !(this is ArrayScope && (this as ArrayScope).IsMultiDynArray)) foreach (TypeScope ts in implemented_interfaces) lst.AddRange(ts.GetNamesAsInObject(ev)); return lst.ToArray(); }
//poluchit imena s klassa s kluchevym slovom //vyzyvaetsja, kogda procedure TClass. tut vse ekzemplarnye i staticheskie public virtual SymInfo[] GetNames(ExpressionVisitor ev, PascalABCCompiler.Parsers.KeywordKind keyword, bool called_in_base) { List<SymInfo> lst = new List<SymInfo>(); foreach (SymScope ss in members) { if (!ss.si.name.StartsWith("$")) { if (keyword != PascalABCCompiler.Parsers.KeywordKind.Function && keyword != PascalABCCompiler.Parsers.KeywordKind.Constructor && keyword != PascalABCCompiler.Parsers.KeywordKind.Destructor/*!(ev.entry_scope is InterfaceUnitScope) && !(ev.entry_scope is ImplementationUnitScope)*/) { if (ss.si.acc_mod == access_modifer.private_modifer) { if (ss.is_static && ev.CheckPrivateForBaseAccess(ev.entry_scope, this)) lst.Add(ss.si); } else if (ss.si.acc_mod == access_modifer.protected_modifer) { if (ss.is_static && ev.CheckForBaseAccess(ev.entry_scope, this)) lst.Add(ss.si); } else if (ss.is_static) lst.Add(ss.si); else if ((ss is ProcScope) && (ss as ProcScope).IsConstructor()) if (!((ss as ProcScope).parameters == null || (ss as ProcScope).parameters.Count == 0) || !called_in_base) lst.Add(ss.si); } else { if (ss is ProcScope && !(ss as ProcScope).already_defined) { if (keyword == PascalABCCompiler.Parsers.KeywordKind.Function || keyword == PascalABCCompiler.Parsers.KeywordKind.Destructor) lst.Add(ss.si); else if ((ss as ProcScope).IsConstructor()) lst.Add(ss.si); } } if (!ss.si.has_doc) UnitDocCache.AddDescribeToComplete(ss); } } if (baseScope != null && keyword != PascalABCCompiler.Parsers.KeywordKind.Constructor && keyword != PascalABCCompiler.Parsers.KeywordKind.Destructor) lst.AddRange(baseScope.GetNames(ev, keyword, true)); /*if (topScope != null) lst.AddRange(topScope.GetNames());*/ return lst.ToArray(); }
//esli naprimer nazhali ctrl-probel(all_name = treu) ili shift-probel (all_names = false) //visitor vsegda nuzhen tak kak hranit scope, gde my nazhali public override SymInfo[] GetNamesInAllTopScopes(bool all_names, ExpressionVisitor ev, bool is_static) { List<SymInfo> lst = new List<SymInfo>(); foreach (SymScope ss in members) { if (ss is ProcScope && (ss as ProcScope).IsConstructor()) continue; if (!ss.si.name.StartsWith("$")) { if (ss.si.acc_mod == access_modifer.private_modifer) { if (ev.CheckPrivateForBaseAccess(ev.entry_scope, this)) if (!is_static) lst.Add(ss.si); else if (ss.is_static) lst.Add(ss.si); } else if (ss.si.acc_mod == access_modifer.protected_modifer) { if (ev.CheckForBaseAccess(ev.entry_scope, this)) if (!is_static) lst.Add(ss.si); else if (ss.is_static) lst.Add(ss.si); } else if (!is_static) lst.Add(ss.si); else if (ss.is_static) lst.Add(ss.si); if (!ss.si.has_doc) UnitDocCache.AddDescribeToComplete(ss); } } if (baseScope != null) lst.AddRange(baseScope.GetNamesAsInBaseClass(ev, is_static)); if (topScope != null) lst.AddRange(topScope.GetNamesInAllTopScopes(all_names, ev, is_static)); return lst.ToArray(); }
/// <summary> /// Получить подсказку параметров метода /// </summary> public string[] GetNameOfMethod(expression expr, string str, int line, int col, int num_param,ref int defIndex, int choose_param_num, out int param_count) { param_count = 0; if (stv.cur_scope == null) return null; if (col +1 > str.Length) col -= str.Length; SymScope si = stv.FindScopeByLocation(line+1,col+1);//stv.cur_scope; if (si == null) { si = stv.FindScopeByLocation(line,col+1); if (si == null) return null; } SetCurrentUsedAssemblies(); ExpressionVisitor ev = new ExpressionVisitor(expr, si, stv); List<ProcScope> scopes = ev.GetOverloadScopes(); bool was_empty_params = false; if (scopes.Count == 0) { RestoreCurrentUsedAssemblies(); return null; } si = scopes[0]; //if (si is ElementScope && (si as ElementScope).sc is ProcScope) si = (si as ElementScope).sc as ProcScope; //if (si is ElementScope && (si as ElementScope).sc is ProcType) si = ((si as ElementScope).sc as ProcType).target; if (si != null && si is ProcScope) { List<string> procs = new List<string>(); List<ProcScope> proc_defs = new List<ProcScope>(); ProcScope ps = si as ProcScope; int i = 0; bool stop = false; ProcScope tmp = ps; while (i < scopes.Count) { if (i == defIndex) { if (tmp.GetParametersCount() != 0) { choose_param_num = tmp.GetParametersCount(); param_count = choose_param_num; } break; } i++; tmp = scopes[i]; } i = 0; while (ps != null) { //if (!ps.si.name.StartsWith("$")) //if (!stop && ((ps.GetParametersCount() >= num_param) || ps.GetParametersCount() == 0 && num_param == 1 && choose_param_num==1)) //if (i == defIndex) param_count = ps.GetParametersCount(); if (!stop && num_param > choose_param_num && ps.GetParametersCount() >= num_param && ps.GetParametersCount() > choose_param_num) { //if (ps.GetParametersCount() >= choose_param_num && choose_param_num == 1 || choose_param_num > 1 && ps.GetParametersCount() > choose_param_num) { defIndex = i; stop = true; param_count = ps.GetParametersCount(); } //System.Diagnostics.Debug.WriteLine(defIndex); } if (ps is CompiledMethodScope) ps.AddDocumentation(AssemblyDocCache.GetDocumentation((ps as CompiledMethodScope).mi)); else if (ps is CompiledConstructorScope) ps.AddDocumentation(AssemblyDocCache.GetDocumentation((ps as CompiledConstructorScope).mi)); else if (ps is ProcScope) { if (!ps.si.has_doc) { ps.AddDocumentation(UnitDocCache.GetDocumentation(ps as ProcScope)); } } if (ps.acc_mod == access_modifer.protected_modifer || ps.acc_mod == access_modifer.private_modifer) { if (ps.acc_mod == access_modifer.private_modifer) { if (ev.IsInOneModule(ev.entry_scope,ps.topScope)) if (!ps.si.not_include && !equal_params(ps,proc_defs)) { procs.Add(ps.si.description); proc_defs.Add(ps); } } else if (ev.CheckForBaseAccess(ev.entry_scope,ps.topScope)) if (!ps.si.not_include && !equal_params(ps,proc_defs)) { procs.Add(ps.si.description); proc_defs.Add(ps); } } else if (!ps.si.not_include) /*if (ps.GetParametersCount() == 0) { if (!was_empty_params) { procs.Add(ps.si.describe); proc_defs.Add(ps); was_empty_params = true; } }*/ if (!equal_params(ps,proc_defs)) { procs.Add(ps.si.description); proc_defs.Add(ps); } i++; if (i<scopes.Count) ps = scopes[i]; else ps = null; } RestoreCurrentUsedAssemblies(); return procs.ToArray(); } RestoreCurrentUsedAssemblies(); return null; }