1
// Copyright (c) AlphaSierraPapa for the SharpDevelop Team
3
// Permission is hereby granted, free of charge, to any person obtaining a copy of this
4
// software and associated documentation files (the "Software"), to deal in the Software
5
// without restriction, including without limitation the rights to use, copy, modify, merge,
6
// publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons
7
// to whom the Software is furnished to do so, subject to the following conditions:
9
// The above copyright notice and this permission notice shall be included in all copies or
10
// substantial portions of the Software.
12
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
13
// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
14
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
15
// FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
16
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
17
// DEALINGS IN THE SOFTWARE.
20
using System.Collections.Generic;
21
using System.Diagnostics.Contracts;
23
namespace ICSharpCode.NRefactory.TypeSystem
26
/// Represents an assembly consisting of source code (parsed files).
28
public interface IProjectContent : IUnresolvedAssembly
31
/// Gets a parsed file by its file name.
33
IParsedFile GetFile(string fileName);
36
/// Gets the list of all parsed files in the project content.
38
IEnumerable<IParsedFile> Files { get; }
41
/// Gets the referenced assemblies.
43
IEnumerable<IAssemblyReference> AssemblyReferences { get; }
46
/// Creates a new <see cref="ICompilation"/> that allows resolving within this project.
49
/// An ICompilation is immutable, it operates on a snapshot of this project.
51
ICompilation CreateCompilation();
54
/// Creates a new <see cref="ICompilation"/> that allows resolving within this project.
56
/// <param name="solutionSnapshot">The parent solution snapshot to use for the compilation.</param>
58
/// An ICompilation is immutable, it operates on a snapshot of this project.
60
ICompilation CreateCompilation(ISolutionSnapshot solutionSnapshot);
63
/// Changes the assembly name of this project content.
65
IProjectContent SetAssemblyName(string newAssemblyName);
68
/// Add assembly references to this project content.
70
IProjectContent AddAssemblyReferences(IEnumerable<IAssemblyReference> references);
73
/// Removes assembly references from this project content.
75
IProjectContent RemoveAssemblyReferences(IEnumerable<IAssemblyReference> references);
78
/// Removes types and attributes from oldFile from the project, and adds those from newFile.
80
IProjectContent UpdateProjectContent(IParsedFile oldFile, IParsedFile newFile);
83
/// Removes types and attributes from oldFiles from the project, and adds those from newFiles.
85
IProjectContent UpdateProjectContent(IEnumerable<IParsedFile> oldFiles, IEnumerable<IParsedFile> newFiles);