// // DocumentContext.cs // // Author: // Mike Krüger // // Copyright (c) 2014 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.Projects; using ICSharpCode.NRefactory.TypeSystem; using MonoDevelop.Ide.TypeSystem; using System.Threading.Tasks; using System.Threading; using Microsoft.CodeAnalysis.Options; using System.Collections.Generic; using MonoDevelop.Ide.Editor.Projection; namespace MonoDevelop.Ide.Editor { /// /// A document context puts a textual document in a semantic context inside a project and gives access /// to the parse information of the textual document. /// public abstract class DocumentContext { /// /// The name of the document. It's the file name for files on disc. /// For unsaved files that name is different. /// public abstract string Name { get; } /// /// Project != null /// public virtual bool HasProject { get { return Project != null; } } /// /// Gets the project this context is in. /// public abstract Project Project { get; } public Microsoft.CodeAnalysis.Workspace RoslynWorkspace { get; protected set; } /// /// Returns the roslyn document for this document. This may return null if it's no compileable document. /// Even if it's a C# file. /// public abstract Microsoft.CodeAnalysis.Document AnalysisDocument { get; } /// /// The parsed document. Contains all syntax information about the text. /// public abstract ParsedDocument ParsedDocument { get; } /// /// If true, the document is part of the ProjectContent. /// public virtual bool IsCompileableInProject { get { return true; } } public virtual T GetContent() where T : class { var t = this as T; if (t != null) return t; return null; } public virtual IEnumerable GetContents() where T : class { var t = this as T; if (t != null) yield return t; } /// /// This is called after the ParsedDocument updated. /// public event EventHandler DocumentParsed; protected void OnDocumentParsed (EventArgs e) { var handler = DocumentParsed; if (handler != null) handler (this, e); } public abstract void AttachToProject (Project project); /// /// Forces a reparse of the document. This call doesn't block the ui thread. /// The next call to ParsedDocument will give always the current parsed document but may block the UI thread. /// public abstract void ReparseDocument (); public abstract OptionSet GetOptionSet (); public abstract ParsedDocument UpdateParseDocument (); // TODO: IMO that needs to be handled differently (this is atm only used in the ASP.NET binding) // Maybe using the file service. Files can be changed/saved w/o beeing opened. public event EventHandler Saved; protected virtual void OnSaved (EventArgs e) { var handler = Saved; if (handler != null) handler (this, e); } internal virtual Task> GetPartialProjectionsAsync (CancellationToken cancellationToken = default(CancellationToken)) { return null; } } }