Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/monodevelop.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'main/src/addins/CSharpBinding/MonoDevelop.CSharp.Refactoring/FindExtensionMethodHandler.cs')
-rw-r--r--main/src/addins/CSharpBinding/MonoDevelop.CSharp.Refactoring/FindExtensionMethodHandler.cs94
1 files changed, 94 insertions, 0 deletions
diff --git a/main/src/addins/CSharpBinding/MonoDevelop.CSharp.Refactoring/FindExtensionMethodHandler.cs b/main/src/addins/CSharpBinding/MonoDevelop.CSharp.Refactoring/FindExtensionMethodHandler.cs
new file mode 100644
index 0000000000..a6035056dd
--- /dev/null
+++ b/main/src/addins/CSharpBinding/MonoDevelop.CSharp.Refactoring/FindExtensionMethodHandler.cs
@@ -0,0 +1,94 @@
+//
+// FindExtensionMethodHandler.cs
+//
+// Author:
+// Mike Krüger <mkrueger@xamarin.com>
+//
+// Copyright (c) 2013 Xamarin Inc. (http://xamarin.com)
+//
+// Permission is hereby granted, free of charge, to any person obtaining a copy
+// of this software and associated documentation files (the "Software"), to deal
+// in the Software without restriction, including without limitation the rights
+// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+// copies of the Software, and to permit persons to whom the Software is
+// furnished to do so, subject to the following conditions:
+//
+// The above copyright notice and this permission notice shall be included in
+// all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+// THE SOFTWARE.
+
+using System;
+using MonoDevelop.Ide;
+using MonoDevelop.Ide.FindInFiles;
+using MonoDevelop.Ide.TypeSystem;
+using MonoDevelop.Core;
+using Microsoft.CodeAnalysis;
+
+namespace MonoDevelop.CSharp.Refactoring
+{
+ class FindExtensionMethodHandler
+ {
+ public static bool CanFindExtensionMethods (ISymbol declaredSymbol, out string description)
+ {
+// var tr = new ICSharpCode.NRefactory.CSharp.CSharpParser ().ParseTypeReference ("global::Thing<int>.Done<string>") as MemberType;
+// Console.WriteLine (tr.Target);
+//
+ description = GettextCatalog.GetString ("Find Extension Methods");
+// return declaredSymbol.Kind == SymbolKind.NamedType;
+ return false;
+ }
+
+ public static void FindExtensionMethods (ISymbol declaredSymbol)
+ {
+ /* using (var monitor = IdeApp.Workbench.ProgressMonitors.GetSearchProgressMonitor (true, true)) {
+ var solution = TypeSystemService.Workspace.CurrentSolution;
+ foreach (var project in solution.Projects) {
+ var comp = project.GetCompilationAsync ().Result;
+ foreach (var type in comp.)
+
+ }
+ }
+ declaredSymbo*/
+ }
+
+
+// public void Run ()
+// {
+// using (var monitor = IdeApp.Workbench.ProgressMonitors.GetSearchProgressMonitor (true, true)) {
+// foreach (var project in IdeApp.ProjectOperations.CurrentSelectedSolution.GetAllProjects ()) {
+// var comp = TypeSystemService.GetCompilation (project);
+// foreach (var type in comp.MainAssembly.GetAllTypeDefinitions ()) {
+// if (!type.IsStatic)
+// continue;
+// foreach (var method in type.GetMethods (m => m.IsStatic)) {
+// if (!method.IsExtensionMethod)
+// continue;
+// IType[] ifTypes;
+// var typeDef = comp.Import (entity);
+// if (typeDef == null)
+// continue;
+// if (!CSharpResolver.IsEligibleExtensionMethod (typeDef, method, true, out ifTypes))
+// continue;
+//
+// var tf = TextFileProvider.Instance.GetReadOnlyTextEditorData (method.Region.FileName);
+// var start = tf.LocationToOffset (method.Region.Begin);
+// tf.SearchRequest.SearchPattern = method.Name;
+// var sr = tf.SearchForward (start);
+// if (sr != null)
+// start = sr.Offset;
+// monitor.ReportResult (new MemberReference (method, method.Region.FileName, start, method.Name.Length));
+// }
+// }
+// }
+// }
+// }
+ }
+}
+