Browse Source

Fixed CSharpCodeCompletion sample.

git-svn-id: svn://svn.sharpdevelop.net/sharpdevelop/trunk@2240 1ccf3a8d-04fe-1044-b7c0-cef0b8235c61
shortcuts
Daniel Grunwald 20 years ago
parent
commit
05f80162ee
  1. 8
      samples/CSharpCodeCompletion/CodeCompletionProvider.cs
  2. 44
      samples/CSharpCodeCompletion/MainForm.cs

8
samples/CSharpCodeCompletion/CodeCompletionProvider.cs

@ -115,9 +115,13 @@ namespace CSharpEditor
/// </summary> /// </summary>
Dom.ExpressionResult FindExpression(TextArea textArea) Dom.ExpressionResult FindExpression(TextArea textArea)
{ {
Dom.VBNet.VBExpressionFinder finder; Dom.IExpressionFinder finder;
if (MainForm.IsVisualBasic) {
finder = new Dom.VBNet.VBExpressionFinder(); finder = new Dom.VBNet.VBExpressionFinder();
return finder.FindExpression(textArea.Document.TextContent, textArea.Caret.Offset); } else {
finder = new Dom.CSharp.CSharpExpressionFinder(MainForm.DummyFileName);
}
return finder.FindExpression(textArea.Document.TextContent, textArea.Caret.Offset - 1);
} }
void AddCompletionData(List<ICompletionData> resultList, ArrayList completionData) void AddCompletionData(List<ICompletionData> resultList, ArrayList completionData)

44
samples/CSharpCodeCompletion/MainForm.cs

@ -52,6 +52,8 @@ namespace CSharpEditor
internal Dom.ICompilationUnit lastCompilationUnit; internal Dom.ICompilationUnit lastCompilationUnit;
Thread parserThread; Thread parserThread;
public static bool IsVisualBasic = false;
/// <summary> /// <summary>
/// Many SharpDevelop.Dom methods take a file name, which is really just a unique identifier /// Many SharpDevelop.Dom methods take a file name, which is really just a unique identifier
/// for a file - Dom methods don't try to access code files on disk, so the file does not have /// for a file - Dom methods don't try to access code files on disk, so the file does not have
@ -59,7 +61,9 @@ namespace CSharpEditor
/// SharpDevelop itself uses internal names of the kind "[randomId]/Class1.cs" to support /// SharpDevelop itself uses internal names of the kind "[randomId]/Class1.cs" to support
/// code-completion in unsaved files. /// code-completion in unsaved files.
/// </summary> /// </summary>
public const string DummyFileName = "edited.vb"; public const string DummyFileName = "edited.cs";
static readonly Dom.LanguageProperties CurrentLanguageProperties = Dom.LanguageProperties.CSharp;
public MainForm() public MainForm()
{ {
@ -68,16 +72,29 @@ namespace CSharpEditor
// //
InitializeComponent(); InitializeComponent();
textEditorControl1.Text = @"Imports System if (IsVisualBasic) {
textEditorControl1.Text = @"
Class A Class A
Sub B Sub B
Dim x As String Dim xx As String
End Sub End Sub
End Class End Class
"; ";
textEditorControl1.SetHighlighting("VB"); textEditorControl1.SetHighlighting("VBNET");
} else {
textEditorControl1.Text = @"using System;
class A
{
void B()
{
string x;
}
}
";
textEditorControl1.SetHighlighting("C#");
}
textEditorControl1.ShowEOLMarkers = false; textEditorControl1.ShowEOLMarkers = false;
CodeCompletionKeyHandler.Attach(this, textEditorControl1); CodeCompletionKeyHandler.Attach(this, textEditorControl1);
HostCallbackImplementation.Register(this); HostCallbackImplementation.Register(this);
@ -91,7 +108,7 @@ End Class
"CSharpCodeCompletion")); "CSharpCodeCompletion"));
myProjectContent = new Dom.DefaultProjectContent(); myProjectContent = new Dom.DefaultProjectContent();
myProjectContent.Language = Dom.LanguageProperties.VBNet; myProjectContent.Language = CurrentLanguageProperties;
} }
protected override void OnLoad(EventArgs e) protected override void OnLoad(EventArgs e)
@ -116,12 +133,18 @@ End Class
"System", "System.Data", "System.Drawing", "System.Xml", "System.Windows.Forms", "Microsoft.VisualBasic" "System", "System.Data", "System.Drawing", "System.Xml", "System.Windows.Forms", "Microsoft.VisualBasic"
}; };
foreach (string assemblyName in referencedAssemblies) { foreach (string assemblyName in referencedAssemblies) {
{ // block for anonymous method { // block for anonymous method (capture assemblyNameCopy correctly)
string assemblyNameCopy = assemblyName; string assemblyNameCopy = assemblyName;
BeginInvoke(new MethodInvoker(delegate { parserThreadLabel.Text = "Loading " + assemblyNameCopy + "..."; })); BeginInvoke(new MethodInvoker(delegate { parserThreadLabel.Text = "Loading " + assemblyNameCopy + "..."; }));
} }
myProjectContent.AddReferencedContent(pcRegistry.GetProjectContentForReference(assemblyName, assemblyName)); myProjectContent.AddReferencedContent(pcRegistry.GetProjectContentForReference(assemblyName, assemblyName));
} }
if (IsVisualBasic) {
myProjectContent.DefaultImports = new Dom.DefaultUsing(myProjectContent);
myProjectContent.DefaultImports.Usings.Add("System");
myProjectContent.DefaultImports.Usings.Add("System.Text");
myProjectContent.DefaultImports.Usings.Add("Microsoft.VisualBasic");
}
BeginInvoke(new MethodInvoker(delegate { parserThreadLabel.Text = "Ready"; })); BeginInvoke(new MethodInvoker(delegate { parserThreadLabel.Text = "Ready"; }));
// Parse the current file every 2 seconds // Parse the current file every 2 seconds
@ -140,7 +163,12 @@ End Class
})); }));
TextReader textReader = new StringReader(code); TextReader textReader = new StringReader(code);
Dom.ICompilationUnit newCompilationUnit; Dom.ICompilationUnit newCompilationUnit;
using (NRefactory.IParser p = NRefactory.ParserFactory.CreateParser(NRefactory.SupportedLanguage.VBNet, textReader)) { NRefactory.SupportedLanguage supportedLanguage;
if (IsVisualBasic)
supportedLanguage = NRefactory.SupportedLanguage.VBNet;
else
supportedLanguage = NRefactory.SupportedLanguage.CSharp;
using (NRefactory.IParser p = NRefactory.ParserFactory.CreateParser(supportedLanguage, textReader)) {
p.Parse(); p.Parse();
newCompilationUnit = ConvertCompilationUnit(p.CompilationUnit); newCompilationUnit = ConvertCompilationUnit(p.CompilationUnit);
} }

Loading…
Cancel
Save