From ba8481653bc6969d84cc677571833b33464904ef Mon Sep 17 00:00:00 2001 From: de4dot Date: Mon, 25 Apr 2016 07:06:45 +0200 Subject: [PATCH] Add all files --- .gitattributes | 4 + .gitignore | 12 + .gitmodules | 15 + Libraries/ICSharpCode.AvalonEdit | 1 + Libraries/ICSharpCode.TreeView | 1 + Libraries/dnlib | 1 + Licenses/CREDITS.txt | 31 + Licenses/GPLv3.txt | 674 ++ Licenses/LICENSE.txt | 18 + Licenses/OtherLicenses.txt | 73 + .../Examples/Example1.Plugin/CodeCtxMenus.cs | 168 + .../Example1.Plugin/Example1.Plugin.csproj | 91 + .../Example1.Plugin/Images/Assembly.png | Bin 0 -> 153 bytes .../Example1.Plugin/MainMenuCommands.cs | 61 + .../Examples/Example1.Plugin/MiscOptions.cs | 37 + .../Examples/Example1.Plugin/MySettings.cs | 100 + .../Example1.Plugin/MySettingsControl.xaml | 13 + .../Example1.Plugin/MySettingsControl.xaml.cs | 9 + .../Examples/Example1.Plugin/MySettingsTab.cs | 65 + Plugins/Examples/Example1.Plugin/Plugin.cs | 28 + .../Properties/AssemblyInfo.cs | 35 + Plugins/Examples/Example1.Plugin/README.md | 10 + .../Example1.Plugin/ToolBarCommands.cs | 42 + .../Example1.Plugin/TreeViewCtxMenus.cs | 160 + .../AssemblyChildNodeTabContent.cs | 211 + .../Example2.Plugin/Example2.Plugin.csproj | 98 + .../Example2.Plugin/Images/EntryPoint.png | Bin 0 -> 221 bytes .../Example2.Plugin/Images/Strings.png | Bin 0 -> 154 bytes .../Example2.Plugin/Images/TextFile.png | Bin 0 -> 239 bytes .../Examples/Example2.Plugin/NewDnSpyFile.cs | 148 + Plugins/Examples/Example2.Plugin/Plugin.cs | 27 + .../Properties/AssemblyInfo.cs | 35 + Plugins/Examples/Example2.Plugin/README.md | 8 + .../Example2.Plugin/Themes/resourcedict.xaml | 24 + .../Example2.Plugin/ToolTipContentCreator.cs | 32 + .../Example2.Plugin/ToolWindowContent.cs | 190 + .../Example2.Plugin/ToolWindowControl.xaml | 35 + .../Example2.Plugin/ToolWindowControl.xaml.cs | 9 + .../Example2.Plugin/TreeNodeDataCreator.cs | 266 + .../ILSpy.Decompiler/ICSharpCode.Decompiler | 1 + Plugins/ILSpy.Decompiler/NRefactory | 1 + .../CSharp/AssemblyInfoTransform.cs | 62 + .../CSharp/BuilderCache.cs | 76 + .../CSharp/BuilderState.cs | 49 + .../CSharp/CSharpLanguage.cs | 515 ++ .../CSharp/DecompilePartialTransform.cs | 75 + .../CSharp/ThreadSafeObjectPool.cs | 57 + .../dnSpy.Languages.ILSpy/IL/ILLanguage.cs | 289 + .../ILAst/ILAstLanguage.cs | 349 + .../dnSpy.Languages.ILSpy/Plugin.cs | 47 + .../Properties/AssemblyInfo.cs | 14 + ...nSpy.Languages.ILSpy.Resources.Designer.cs | 396 + .../dnSpy.Languages.ILSpy.Resources.resx | 231 + .../dnSpy.Languages.ILSpy.Resources.ru.resx | 231 + ...dnSpy.Languages.ILSpy.Resources.zh-CN.resx | 231 + .../Settings/CSharpDecompilerSettingsTab.cs | 220 + .../DecompilerAppSettingsModifiedListener.cs | 75 + .../Settings/DecompilerSettingsImpl.cs | 115 + .../Settings/DecompilerSettingsTabCreator.cs | 42 + .../ILAstLanguageDecompilerSettings.cs | 49 + .../Settings/ILDecompilerSettingsTab.cs | 67 + .../Settings/ILLanguageDecompilerSettings.cs | 84 + .../Settings/ILSettings.cs | 159 + .../Settings/LanguageDecompilerSettings.cs | 239 + .../Settings/LanguageSettingsManager.cs | 66 + .../Settings/SettingsConstants.cs | 44 + .../Themes/wpf.styles.templates.xaml | 49 + .../VB/ILSpyEnvironmentProvider.cs | 145 + .../dnSpy.Languages.ILSpy/VB/VBLanguage.cs | 327 + .../VB/VBTextOutputFormatter.cs | 295 + .../XmlDoc/AddXmlDocTransform.cs | 65 + .../XmlDoc/StringLineIterator.cs | 98 + .../dnSpy.Languages.ILSpy/XmlDoc/SubString.cs | 42 + .../XmlDoc/XmlDocLine.cs | 163 + .../dnSpy.Languages.ILSpy.csproj | 146 + Plugins/dnSpy.Analyzer/AnalyzerManager.cs | 391 + Plugins/dnSpy.Analyzer/AnalyzerSettings.cs | 129 + .../AnalyzerToolWindowContent.cs | 102 + .../AnalyzerTreeNodeDataContext.cs | 36 + Plugins/dnSpy.Analyzer/Commands.cs | 234 + Plugins/dnSpy.Analyzer/Images/Copy.png | Bin 0 -> 194 bytes Plugins/dnSpy.Analyzer/Images/Delete.png | Bin 0 -> 523 bytes Plugins/dnSpy.Analyzer/Images/Search.png | Bin 0 -> 522 bytes Plugins/dnSpy.Analyzer/Plugin.cs | 47 + .../dnSpy.Analyzer/Properties/AssemblyInfo.cs | 14 + .../dnSpy.Analyzer.Resources.Designer.cs | 360 + .../Properties/dnSpy.Analyzer.Resources.resx | 219 + .../dnSpy.Analyzer.Resources.ru.resx | 219 + .../dnSpy.Analyzer.Resources.zh-CN.resx | 219 + .../TreeNodes/AnalyzerTreeNodeData.cs | 162 + .../dnSpy.Analyzer/TreeNodes/AssemblyNode.cs | 49 + .../TreeNodes/AsyncFetchChildrenHelper.cs | 93 + .../TreeNodes/AttributeAppliedToNode.cs | 366 + Plugins/dnSpy.Analyzer/TreeNodes/Commands.cs | 391 + .../dnSpy.Analyzer/TreeNodes/EntityNode.cs | 53 + .../TreeNodes/EventAccessorNode.cs | 40 + .../TreeNodes/EventFiredByNode.cs | 130 + Plugins/dnSpy.Analyzer/TreeNodes/EventNode.cs | 107 + .../TreeNodes/EventOverridesNode.cs | 68 + .../TreeNodes/FieldAccessNode.cs | 118 + Plugins/dnSpy.Analyzer/TreeNodes/FieldNode.cs | 67 + Plugins/dnSpy.Analyzer/TreeNodes/Helpers.cs | 146 + .../TreeNodes/IAnalyzerTreeNodeData.cs | 53 + .../TreeNodes/IAnalyzerTreeNodeDataContext.cs | 35 + .../TreeNodes/IAsyncCancellable.cs | 24 + .../InterfaceEventImplementedByNode.cs | 84 + .../InterfaceMethodImplementedByNode.cs | 75 + .../InterfacePropertyImplementedByNode.cs | 83 + .../dnSpy.Analyzer/TreeNodes/MethodNode.cs | 87 + .../TreeNodes/MethodOverridesNode.cs | 79 + .../TreeNodes/MethodUsedByNode.cs | 89 + .../TreeNodes/MethodUsesNode.cs | 88 + .../dnSpy.Analyzer/TreeNodes/ModuleNode.cs | 51 + .../TreeNodes/PropertyAccessorNode.cs | 40 + .../dnSpy.Analyzer/TreeNodes/PropertyNode.cs | 103 + .../TreeNodes/PropertyOverridesNode.cs | 69 + .../TreeNodes/ScopedWhereUsedAnalyzer.cs | 311 + .../dnSpy.Analyzer/TreeNodes/SearchNode.cs | 99 + Plugins/dnSpy.Analyzer/TreeNodes/SourceRef.cs | 33 + .../TreeNodes/TypeExposedByNode.cs | 147 + .../TreeNodes/TypeExtensionMethodsNode.cs | 79 + .../TreeNodes/TypeInstantiationsNode.cs | 83 + Plugins/dnSpy.Analyzer/TreeNodes/TypeNode.cs | 75 + .../TreeNodes/TypeUsedByNode.cs | 176 + .../TreeNodes/VirtualMethodUsedByNode.cs | 132 + Plugins/dnSpy.Analyzer/TreeTraversal.cs | 109 + Plugins/dnSpy.Analyzer/dnSpy.Analyzer.csproj | 138 + .../Assembly/AssemblyCommands.cs | 490 ++ .../Assembly/AssemblyOptions.cs | 81 + .../Assembly/AssemblyOptionsDlg.xaml | 179 + .../Assembly/AssemblyOptionsDlg.xaml.cs | 34 + .../Assembly/AssemblyOptionsVM.cs | 311 + .../Commands/AsmEditorContext.cs | 30 + .../Commands/ClipboardDataHolder.cs | 133 + .../Commands/CodeContextMenuHandler.cs | 64 + .../CodeContextMenuHandlerCommandProxy.cs | 70 + .../dnSpy.AsmEditor/Commands/CommandUtils.cs | 53 + .../Commands/ContextMenuHandler.cs | 32 + .../Commands/DeletableNodes.cs | 88 + .../Commands/EditMenuHandler.cs | 49 + .../Commands/EditMenuHandlerCommandProxy.cs | 53 + .../Commands/FileMenuHandler.cs | 49 + .../Commands/FilesContextMenuHandler.cs | 43 + .../dnSpy.AsmEditor/Commands/IIndexedItem.cs | 25 + .../Commands/IndexObservableCollection.cs | 270 + .../Commands/InstructionCommands.cs | 171 + .../Commands/ListBoxHelperBase.cs | 424 + .../Commands/MyObservableCollection.cs | 110 + .../Commands/NamespaceNodeCreator.cs | 70 + Plugins/dnSpy.AsmEditor/Commands/RefFinder.cs | 63 + .../Commands/RootDnSpyFileNodeCreator.cs | 88 + .../Converters/CilObjectConverter.cs | 58 + ...InstructionOperandTextBoxStyleConverter.cs | 37 + .../DnlibDialogs/CAArgumentVM.cs | 411 + .../DnlibDialogs/CANamedArgumentControl.xaml | 56 + .../CANamedArgumentControl.xaml.cs | 37 + .../DnlibDialogs/CANamedArgumentVM.cs | 348 + .../DnlibDialogs/CANamedArgumentsControl.xaml | 34 + .../CANamedArgumentsControl.xaml.cs | 28 + .../DnlibDialogs/CANamedArgumentsVM.cs | 49 + .../DnlibDialogs/ConstantControl.xaml | 42 + .../DnlibDialogs/ConstantControl.xaml.cs | 28 + .../DnlibDialogs/ConstantTypeControl.xaml | 264 + .../DnlibDialogs/ConstantTypeControl.xaml.cs | 39 + .../DnlibDialogs/ConstantTypeDlg.xaml | 60 + .../DnlibDialogs/ConstantTypeDlg.xaml.cs | 28 + .../DnlibDialogs/ConstantTypeVM.cs | 1139 +++ .../DnlibDialogs/ConstantVM.cs | 102 + .../BooleanToGridrowLengthConverter.cs | 43 + .../Converters/RadioButtonConverter.cs | 34 + .../CreateTypeSigArrayControl.xaml | 82 + .../CreateTypeSigArrayControl.xaml.cs | 28 + .../DnlibDialogs/CreateTypeSigArrayDlg.xaml | 65 + .../CreateTypeSigArrayDlg.xaml.cs | 28 + .../DnlibDialogs/CreateTypeSigArrayVM.cs | 157 + .../DnlibDialogs/CustomAttributeControl.xaml | 74 + .../CustomAttributeControl.xaml.cs | 37 + .../DnlibDialogs/CustomAttributeDlg.xaml | 55 + .../DnlibDialogs/CustomAttributeDlg.xaml.cs | 28 + .../DnlibDialogs/CustomAttributeOptions.cs | 47 + .../DnlibDialogs/CustomAttributeVM.cs | 259 + .../DnlibDialogs/CustomAttributesControl.xaml | 29 + .../CustomAttributesControl.xaml.cs | 37 + .../DnlibDialogs/CustomAttributesVM.cs | 42 + .../DnlibDialogs/DeclSecuritiesControl.xaml | 29 + .../DeclSecuritiesControl.xaml.cs | 37 + .../DnlibDialogs/DeclSecuritiesVM.cs | 42 + .../DnlibDialogs/DeclSecurityControl.xaml | 65 + .../DnlibDialogs/DeclSecurityControl.xaml.cs | 28 + .../DnlibDialogs/DeclSecurityDlg.xaml | 53 + .../DnlibDialogs/DeclSecurityDlg.xaml.cs | 28 + .../DnlibDialogs/DeclSecurityOptions.cs | 57 + .../DnlibDialogs/DeclSecurityVM.cs | 180 + .../dnSpy.AsmEditor/DnlibDialogs/DlgUtils.cs | 114 + .../DnlibDialogs/EnumDataFieldVM.cs | 260 + .../DnlibDialogs/GenericParamControl.xaml | 98 + .../DnlibDialogs/GenericParamControl.xaml.cs | 35 + .../DnlibDialogs/GenericParamDlg.xaml | 53 + .../DnlibDialogs/GenericParamDlg.xaml.cs | 28 + .../DnlibDialogs/GenericParamOptions.cs | 60 + .../DnlibDialogs/GenericParamVM.cs | 199 + .../DnlibDialogs/GenericParamsControl.xaml | 29 + .../DnlibDialogs/GenericParamsControl.xaml.cs | 37 + .../DnlibDialogs/GenericParamsVM.cs | 51 + .../DnlibDialogs/ImplMapControl.xaml | 65 + .../DnlibDialogs/ImplMapControl.xaml.cs | 28 + .../dnSpy.AsmEditor/DnlibDialogs/ImplMapVM.cs | 181 + .../dnSpy.AsmEditor/DnlibDialogs/ListVM.cs | 164 + .../DnlibDialogs/ListVMControl.xaml | 79 + .../DnlibDialogs/ListVMControl.xaml.cs | 38 + .../DnlibDialogs/MarshalTypeControl.xaml | 125 + .../DnlibDialogs/MarshalTypeControl.xaml.cs | 28 + .../DnlibDialogs/MarshalTypeVM.cs | 655 ++ .../DnlibDialogs/MemberPickerDlg.xaml | 92 + .../DnlibDialogs/MemberPickerDlg.xaml.cs | 78 + .../DnlibDialogs/MemberPickerVM.cs | 400 + .../DnlibDialogs/MemberRefControl.xaml | 102 + .../DnlibDialogs/MemberRefControl.xaml.cs | 44 + .../DnlibDialogs/MemberRefDlg.xaml | 53 + .../DnlibDialogs/MemberRefDlg.xaml.cs | 28 + .../DnlibDialogs/MemberRefOptions.cs | 53 + .../DnlibDialogs/MemberRefVM.cs | 255 + .../DnlibDialogs/MethodDefVM.cs | 71 + .../DnlibDialogs/MethodDefsControl.xaml | 29 + .../DnlibDialogs/MethodDefsControl.xaml.cs | 37 + .../DnlibDialogs/MethodDefsVM.cs | 41 + .../DnlibDialogs/MethodOverrideOptions.cs | 39 + .../DnlibDialogs/MethodOverrideVM.cs | 88 + .../DnlibDialogs/MethodOverridesControl.xaml | 29 + .../MethodOverridesControl.xaml.cs | 37 + .../DnlibDialogs/MethodOverridesVM.cs | 42 + .../DnlibDialogs/MethodSigCreatorControl.xaml | 113 + .../MethodSigCreatorControl.xaml.cs | 37 + .../DnlibDialogs/MethodSigCreatorDlg.xaml | 61 + .../DnlibDialogs/MethodSigCreatorDlg.xaml.cs | 28 + .../DnlibDialogs/MethodSigCreatorOptions.cs | 63 + .../DnlibDialogs/MethodSigCreatorVM.cs | 273 + .../DnlibDialogs/MethodSpecControl.xaml | 70 + .../DnlibDialogs/MethodSpecControl.xaml.cs | 37 + .../DnlibDialogs/MethodSpecDlg.xaml | 53 + .../DnlibDialogs/MethodSpecDlg.xaml.cs | 28 + .../DnlibDialogs/MethodSpecOptions.cs | 50 + .../DnlibDialogs/MethodSpecVM.cs | 131 + .../DnlibDialogs/ModelUtils.cs | 135 + Plugins/dnSpy.AsmEditor/DnlibDialogs/Null.cs | 34 + .../DnlibDialogs/ObjectListDataFieldVM.cs | 144 + .../DnlibDialogs/ParamDefControl.xaml | 83 + .../DnlibDialogs/ParamDefControl.xaml.cs | 35 + .../DnlibDialogs/ParamDefDlg.xaml | 53 + .../DnlibDialogs/ParamDefDlg.xaml.cs | 28 + .../DnlibDialogs/ParamDefOptions.cs | 59 + .../DnlibDialogs/ParamDefVM.cs | 224 + .../DnlibDialogs/ParamDefsControl.xaml | 29 + .../DnlibDialogs/ParamDefsControl.xaml.cs | 37 + .../DnlibDialogs/ParamDefsVM.cs | 51 + .../SecurityAttributeControl.xaml | 46 + .../SecurityAttributeControl.xaml.cs | 37 + .../DnlibDialogs/SecurityAttributeDlg.xaml | 55 + .../DnlibDialogs/SecurityAttributeDlg.xaml.cs | 28 + .../DnlibDialogs/SecurityAttributeVM.cs | 150 + .../SecurityAttributesControl.xaml | 29 + .../SecurityAttributesControl.xaml.cs | 37 + .../DnlibDialogs/SecurityAttributesVM.cs | 42 + .../TypeDefOrRefAndCAControl.xaml | 37 + .../TypeDefOrRefAndCAControl.xaml.cs | 28 + .../DnlibDialogs/TypeDefOrRefAndCADlg.xaml | 52 + .../DnlibDialogs/TypeDefOrRefAndCADlg.xaml.cs | 28 + .../DnlibDialogs/TypeDefOrRefAndCAOptions.cs | 63 + .../DnlibDialogs/TypeDefOrRefAndCAVM.cs | 101 + .../TypeDefOrRefAndCAsControl.xaml | 29 + .../TypeDefOrRefAndCAsControl.xaml.cs | 42 + .../DnlibDialogs/TypeDefOrRefAndCAsVM.cs | 50 + .../DnlibDialogs/TypeSigCreatorControl.xaml | 138 + .../TypeSigCreatorControl.xaml.cs | 40 + .../DnlibDialogs/TypeSigCreatorDlg.xaml | 52 + .../DnlibDialogs/TypeSigCreatorDlg.xaml.cs | 28 + .../DnlibDialogs/TypeSigCreatorOptions.cs | 82 + .../DnlibDialogs/TypeSigCreatorVM.cs | 465 ++ .../dnSpy.AsmEditor/DnlibDialogs/TypeSigVM.cs | 231 + .../dnSpy.AsmEditor/Event/EventDefCommands.cs | 522 ++ .../dnSpy.AsmEditor/Event/EventDefOptions.cs | 74 + .../Event/EventOptionsDlg.xaml | 130 + .../Event/EventOptionsDlg.xaml.cs | 37 + .../dnSpy.AsmEditor/Event/EventOptionsVM.cs | 277 + Plugins/dnSpy.AsmEditor/ExtensionMethods.cs | 29 + .../dnSpy.AsmEditor/Field/FieldDefCommands.cs | 540 ++ .../dnSpy.AsmEditor/Field/FieldDefOptions.cs | 86 + .../Field/FieldOptionsDlg.xaml | 145 + .../Field/FieldOptionsDlg.xaml.cs | 28 + .../dnSpy.AsmEditor/Field/FieldOptionsVM.cs | 342 + .../dnSpy.AsmEditor/Hex/AsmEdHexDocument.cs | 49 + Plugins/dnSpy.AsmEditor/Hex/Commands.cs | 1661 ++++ ...exAddressReferenceFileTabContentCreator.cs | 94 + .../Hex/HexBoxFileTabContent.cs | 293 + Plugins/dnSpy.AsmEditor/Hex/HexBoxUIState.cs | 35 + .../Hex/HexBoxUIStateSerializer.cs | 86 + .../dnSpy.AsmEditor/Hex/HexBoxUndoCommand.cs | 130 + .../dnSpy.AsmEditor/Hex/HexBoxUndoManager.cs | 115 + .../dnSpy.AsmEditor/Hex/HexDocumentManager.cs | 194 + Plugins/dnSpy.AsmEditor/Hex/HexTabSaver.cs | 75 + .../Hex/HexUndoableDocumentsProvider.cs | 64 + .../dnSpy.AsmEditor/Hex/IUndoHexDocument.cs | 24 + .../dnSpy.AsmEditor/Hex/InstructionUtils.cs | 95 + .../Hex/MDTableContextMenuCommands.cs | 574 ++ Plugins/dnSpy.AsmEditor/Hex/Nodes/HexField.cs | 985 +++ .../Hex/Nodes/HexFileTabContent.cs | 170 + .../Hex/Nodes/HexFileTreeNodeDataFinder.cs | 43 + Plugins/dnSpy.AsmEditor/Hex/Nodes/HexNode.cs | 96 + Plugins/dnSpy.AsmEditor/Hex/Nodes/HexUtils.cs | 26 + Plugins/dnSpy.AsmEditor/Hex/Nodes/HexVM.cs | 44 + .../Hex/Nodes/ImageCor20HeaderNode.cs | 69 + .../Hex/Nodes/ImageCor20HeaderVM.cs | 140 + .../Hex/Nodes/ImageDosHeaderNode.cs | 62 + .../Hex/Nodes/ImageDosHeaderVM.cs | 258 + .../Hex/Nodes/ImageFileHeaderNode.cs | 62 + .../Hex/Nodes/ImageFileHeaderVM.cs | 159 + .../Hex/Nodes/ImageOptionalHeader32Node.cs | 62 + .../Hex/Nodes/ImageOptionalHeader32VM.cs | 109 + .../Hex/Nodes/ImageOptionalHeader64Node.cs | 62 + .../Hex/Nodes/ImageOptionalHeader64VM.cs | 102 + .../Hex/Nodes/ImageOptionalHeaderVM.cs | 347 + .../Hex/Nodes/ImageSectionHeaderNode.cs | 81 + .../Hex/Nodes/ImageSectionHeaderVM.cs | 160 + .../Hex/Nodes/MetaDataTableNode.cs | 197 + .../Hex/Nodes/MetaDataTableRecordNode.cs | 256 + .../Hex/Nodes/MetaDataTableRecordVM.cs | 1308 ++++ .../Hex/Nodes/MetaDataTableVM.cs | 720 ++ Plugins/dnSpy.AsmEditor/Hex/Nodes/PENode.cs | 198 + .../Hex/Nodes/PETreeNodeDataCreator.cs | 80 + .../Hex/Nodes/StorageHeaderNode.cs | 62 + .../Hex/Nodes/StorageHeaderVM.cs | 63 + .../Hex/Nodes/StorageSignatureNode.cs | 62 + .../Hex/Nodes/StorageSignatureVM.cs | 84 + .../Hex/Nodes/StorageStreamNode.cs | 138 + .../Hex/Nodes/StorageStreamVM.cs | 63 + .../Hex/Nodes/TablesStreamNode.cs | 97 + .../Hex/Nodes/TablesStreamVM.cs | 457 ++ .../TokenReferenceFileTabContentCreator.cs | 49 + .../Hex/Nodes/VirtualizedList.cs | 128 + .../Hex/Nodes/wpf.styles.templates.xaml | 4548 +++++++++++ Plugins/dnSpy.AsmEditor/Hex/TableSorter.cs | 191 + .../Hex/WriteHexUndoCommand.cs | 81 + .../dnSpy.AsmEditor/Images/AddException.png | Bin 0 -> 261 bytes Plugins/dnSpy.AsmEditor/Images/AddLocal.png | Bin 0 -> 393 bytes Plugins/dnSpy.AsmEditor/Images/AddNewItem.png | Bin 0 -> 310 bytes Plugins/dnSpy.AsmEditor/Images/ArrowDown.png | Bin 0 -> 189 bytes Plugins/dnSpy.AsmEditor/Images/ArrowUp.png | Bin 0 -> 276 bytes .../Images/AssemblyToModule.png | Bin 0 -> 271 bytes Plugins/dnSpy.AsmEditor/Images/Binary.png | Bin 0 -> 149 bytes Plugins/dnSpy.AsmEditor/Images/BinaryFile.png | Bin 0 -> 247 bytes Plugins/dnSpy.AsmEditor/Images/Branch.png | Bin 0 -> 392 bytes Plugins/dnSpy.AsmEditor/Images/Class.png | Bin 0 -> 212 bytes Plugins/dnSpy.AsmEditor/Images/Copy.png | Bin 0 -> 194 bytes Plugins/dnSpy.AsmEditor/Images/Cut.png | Bin 0 -> 319 bytes Plugins/dnSpy.AsmEditor/Images/Delete.png | Bin 0 -> 523 bytes .../dnSpy.AsmEditor/Images/DeleteHistory.png | Bin 0 -> 560 bytes Plugins/dnSpy.AsmEditor/Images/Field.png | Bin 0 -> 216 bytes Plugins/dnSpy.AsmEditor/Images/Generic.png | Bin 0 -> 235 bytes Plugins/dnSpy.AsmEditor/Images/ILEditor.png | Bin 0 -> 148 bytes Plugins/dnSpy.AsmEditor/Images/MetaData.png | Bin 0 -> 307 bytes Plugins/dnSpy.AsmEditor/Images/Method.png | Bin 0 -> 276 bytes Plugins/dnSpy.AsmEditor/Images/ModuleFile.png | Bin 0 -> 244 bytes .../Images/ModuleToAssembly.png | Bin 0 -> 257 bytes Plugins/dnSpy.AsmEditor/Images/NOP.png | Bin 0 -> 213 bytes Plugins/dnSpy.AsmEditor/Images/NameSpace.png | Bin 0 -> 250 bytes .../dnSpy.AsmEditor/Images/NewAssembly.png | Bin 0 -> 266 bytes .../Images/NewAssemblyModule.png | Bin 0 -> 260 bytes Plugins/dnSpy.AsmEditor/Images/NewBinary.png | Bin 0 -> 279 bytes Plugins/dnSpy.AsmEditor/Images/NewClass.png | Bin 0 -> 455 bytes Plugins/dnSpy.AsmEditor/Images/NewEvent.png | Bin 0 -> 319 bytes Plugins/dnSpy.AsmEditor/Images/NewField.png | Bin 0 -> 343 bytes Plugins/dnSpy.AsmEditor/Images/NewImage.png | Bin 0 -> 298 bytes Plugins/dnSpy.AsmEditor/Images/NewMethod.png | Bin 0 -> 402 bytes .../dnSpy.AsmEditor/Images/NewProperty.png | Bin 0 -> 374 bytes .../dnSpy.AsmEditor/Images/NewResource.png | Bin 0 -> 270 bytes .../Images/NewResourcesFile.png | Bin 0 -> 311 bytes Plugins/dnSpy.AsmEditor/Images/Open.png | Bin 0 -> 411 bytes Plugins/dnSpy.AsmEditor/Images/Paste.png | Bin 0 -> 265 bytes Plugins/dnSpy.AsmEditor/Images/Redo.png | Bin 0 -> 565 bytes Plugins/dnSpy.AsmEditor/Images/SaveAll.png | Bin 0 -> 251 bytes Plugins/dnSpy.AsmEditor/Images/Settings.png | Bin 0 -> 274 bytes .../dnSpy.AsmEditor/Images/ToUncondBranch.png | Bin 0 -> 404 bytes Plugins/dnSpy.AsmEditor/Images/Undo.png | Bin 0 -> 478 bytes .../Method/MethodDefCommands.cs | 627 ++ .../Method/MethodDefOptions.cs | 87 + .../Method/MethodOptionsDlg.xaml | 175 + .../Method/MethodOptionsDlg.xaml.cs | 28 + .../dnSpy.AsmEditor/Method/MethodOptionsVM.cs | 439 ++ .../dnSpy.AsmEditor/MethodBody/BodyUtils.cs | 691 ++ .../MethodBody/CilBodyOptions.cs | 82 + .../dnSpy.AsmEditor/MethodBody/CilBodyVM.cs | 890 +++ .../MethodBody/ComboBoxAttachedProps.cs | 35 + .../MethodBody/ExceptionHandlerOptions.cs | 62 + .../MethodBody/ExceptionHandlerVM.cs | 214 + .../MethodBody/ExceptionHandlersListHelper.cs | 167 + .../MethodBody/FastClickButton.cs | 37 + .../MethodBody/IEditOperand.cs | 29 + .../MethodBody/InstructionOperandControl.cs | 211 + .../MethodBody/InstructionOperandVM.cs | 571 ++ .../MethodBody/InstructionOptions.cs | 50 + .../MethodBody/InstructionVM.cs | 255 + .../MethodBody/InstructionsListHelper.cs | 646 ++ .../MethodBody/LocalOptions.cs | 49 + Plugins/dnSpy.AsmEditor/MethodBody/LocalVM.cs | 174 + .../MethodBody/LocalsListHelper.cs | 131 + .../MethodBody/MethodBodyCommands.cs | 312 + .../MethodBody/MethodBodyControl.xaml | 349 + .../MethodBody/MethodBodyControl.xaml.cs | 66 + .../MethodBody/MethodBodyDlg.xaml | 53 + .../MethodBody/MethodBodyDlg.xaml.cs | 28 + .../MethodBody/MethodBodyOptions.cs | 71 + .../MethodBody/MethodBodyType.cs | 26 + .../MethodBody/MethodBodyVM.cs | 152 + .../MethodBody/NativeMethodBodyOptions.cs | 43 + .../MethodBody/NativeMethodBodyVM.cs | 65 + .../MethodBody/SwitchInstructionVM.cs | 49 + .../MethodBody/SwitchOperandControl.xaml | 76 + .../MethodBody/SwitchOperandControl.xaml.cs | 41 + .../MethodBody/SwitchOperandDlg.xaml | 53 + .../MethodBody/SwitchOperandDlg.xaml.cs | 28 + .../MethodBody/SwitchOperandVM.cs | 102 + .../MethodBody/SwitchOperandsListHelper.cs | 70 + Plugins/dnSpy.AsmEditor/Module/ClrVersion.cs | 52 + .../Module/ClrVersionValues.cs | 68 + .../dnSpy.AsmEditor/Module/ModuleCommands.cs | 901 +++ .../dnSpy.AsmEditor/Module/ModuleOptions.cs | 92 + .../Module/ModuleOptionsDlg.xaml | 288 + .../Module/ModuleOptionsDlg.xaml.cs | 37 + .../dnSpy.AsmEditor/Module/ModuleOptionsVM.cs | 638 ++ Plugins/dnSpy.AsmEditor/Module/ModuleUtils.cs | 92 + .../Module/NetModuleOptions.cs | 29 + .../Module/NetModuleOptionsDlg.xaml | 74 + .../Module/NetModuleOptionsDlg.xaml.cs | 28 + .../Module/NetModuleOptionsVM.cs | 89 + .../Namespace/NamespaceCommands.cs | 563 ++ .../Namespace/NamespaceDlg.xaml | 66 + .../Namespace/NamespaceDlg.xaml.cs | 28 + .../dnSpy.AsmEditor/Namespace/NamespaceVM.cs | 52 + Plugins/dnSpy.AsmEditor/Plugin.cs | 64 + .../Properties/AssemblyInfo.cs | 14 + .../dnSpy.AsmEditor.Resources.Designer.cs | 6937 +++++++++++++++++ .../Properties/dnSpy.AsmEditor.Resources.resx | 2417 ++++++ .../dnSpy.AsmEditor.Resources.ru.resx | 2415 ++++++ .../dnSpy.AsmEditor.Resources.zh-CN.resx | 2416 ++++++ .../Property/PropertyDefCommands.cs | 519 ++ .../Property/PropertyDefOptions.cs | 79 + .../Property/PropertyOptionsDlg.xaml | 112 + .../Property/PropertyOptionsDlg.xaml.cs | 28 + .../Property/PropertyOptionsVM.cs | 224 + .../Resources/ImageListDlg.xaml | 90 + .../Resources/ImageListDlg.xaml.cs | 28 + .../Resources/ImageListStreamerControl.xaml | 35 + .../ImageListStreamerControl.xaml.cs | 37 + .../Resources/ImageListStreamerVM.cs | 41 + .../dnSpy.AsmEditor/Resources/ImageListVM.cs | 133 + .../ImageResourceElementControl.xaml | 46 + .../ImageResourceElementControl.xaml.cs | 43 + .../Resources/ImageResourceElementDlg.xaml | 57 + .../Resources/ImageResourceElementDlg.xaml.cs | 28 + .../Resources/ImageResourceElementVM.cs | 112 + Plugins/dnSpy.AsmEditor/Resources/ImageVM.cs | 40 + .../Resources/ResourceCommands.cs | 2568 ++++++ .../Resources/ResourceControl.xaml | 58 + .../Resources/ResourceControl.xaml.cs | 43 + .../Resources/ResourceDlg.xaml | 55 + .../Resources/ResourceDlg.xaml.cs | 28 + .../Resources/ResourceElementControl.xaml | 60 + .../Resources/ResourceElementControl.xaml.cs | 51 + .../Resources/ResourceElementDlg.xaml | 55 + .../Resources/ResourceElementDlg.xaml.cs | 28 + .../Resources/ResourceElementOptions.cs | 45 + .../Resources/ResourceElementVM.cs | 416 + .../Resources/ResourceOptions.cs | 83 + .../dnSpy.AsmEditor/Resources/ResourceVM.cs | 227 + .../dnSpy.AsmEditor/Resources/UserTypeVM.cs | 163 + .../SaveModule/CharacteristicsHelper.cs | 43 + .../SaveModule/DocumentSaver.cs | 153 + .../SaveModule/MmapDisabler.cs | 72 + .../dnSpy.AsmEditor/SaveModule/ModuleSaver.cs | 332 + .../dnSpy.AsmEditor/SaveModule/PathUtils.cs | 80 + .../SaveModule/SaveHexOptionsDlg.xaml | 66 + .../SaveModule/SaveHexOptionsDlg.xaml.cs | 34 + .../SaveModule/SaveHexOptionsVM.cs | 63 + .../SaveModule/SaveModuleCommand.cs | 154 + .../SaveModule/SaveModuleOptionsDlg.xaml | 468 ++ .../SaveModule/SaveModuleOptionsDlg.xaml.cs | 34 + .../SaveModule/SaveModuleOptionsVM.cs | 1286 +++ .../SaveModule/SaveModuleWindow.cs | 99 + .../SaveModule/SaveMultiModuleDlg.xaml | 180 + .../SaveModule/SaveMultiModuleDlg.xaml.cs | 44 + .../SaveModule/SaveMultiModuleVM.cs | 411 + .../SaveModule/SaveOptionsType.cs | 25 + .../SaveModule/SaveOptionsVM.cs | 77 + .../SaveModule/SaveSingleModuleDlg.xaml | 116 + .../SaveModule/SaveSingleModuleDlg.xaml.cs | 26 + .../Themes/wpf.styles.templates.xaml | 779 ++ .../dnSpy.AsmEditor/Types/TypeDefCommands.cs | 695 ++ .../dnSpy.AsmEditor/Types/TypeDefOptions.cs | 93 + .../dnSpy.AsmEditor/Types/TypeOptionsDlg.xaml | 160 + .../Types/TypeOptionsDlg.xaml.cs | 28 + .../dnSpy.AsmEditor/Types/TypeOptionsVM.cs | 570 ++ Plugins/dnSpy.AsmEditor/UndoRedo/Commands.cs | 58 + .../DnSpyFileUndoableDocumentsProvider.cs | 132 + .../dnSpy.AsmEditor/UndoRedo/IUndoCommand.cs | 56 + .../dnSpy.AsmEditor/UndoRedo/IUndoObject.cs | 25 + .../UndoRedo/IUndoableDocumentsProvider.cs | 29 + .../UndoRedo/ToolbarCommands.cs | 64 + .../UndoRedo/UndoCommandManager.cs | 468 ++ .../UndoRedo/UndoCommandManagerEventArgs.cs | 42 + .../dnSpy.AsmEditor/UndoRedo/UndoObject.cs | 35 + .../UndoRedo/UndoRedoIFileListListener.cs | 70 + .../UndoRedo/UndoRedoMenuCommands.cs | 37 + .../UndoRedo/UndoRoutedCommands.cs | 36 + .../ViewHelpers/CreateConstantType.cs | 86 + .../ViewHelpers/CreateMethodPropertySig.cs | 51 + .../ViewHelpers/CreateTypeSigArray.cs | 49 + .../ViewHelpers/DnlibTypePicker.cs | 103 + .../ViewHelpers/EditCustomAttribute.cs | 47 + .../ViewHelpers/EditDeclSecurity.cs | 47 + .../ViewHelpers/EditGenericParam.cs | 47 + .../dnSpy.AsmEditor/ViewHelpers/EditImage.cs | 68 + .../ViewHelpers/EditMemberRef.cs | 47 + .../ViewHelpers/EditMethodDef.cs | 49 + .../ViewHelpers/EditMethodOverride.cs | 48 + .../ViewHelpers/EditMethodSpec.cs | 47 + .../ViewHelpers/EditParamDef.cs | 47 + .../ViewHelpers/EditSecurityAttribute.cs | 47 + .../ViewHelpers/EditTypeDefOrRefAndCA.cs | 47 + .../ViewHelpers/ICreateConstantType.cs | 42 + .../ViewHelpers/ICreateMethodPropertySig.cs | 33 + .../ViewHelpers/ICreateTypeSigArray.cs | 35 + .../ViewHelpers/IDnlibTypePicker.cs | 36 + Plugins/dnSpy.AsmEditor/ViewHelpers/IEdit.cs | 30 + .../ViewHelpers/IOpenAssembly.cs | 30 + .../dnSpy.AsmEditor/ViewHelpers/IOpenFile.cs | 29 + .../ViewHelpers/IOpenPublicKeyFile.cs | 31 + .../ViewHelpers/ISelectItems.cs | 30 + .../ViewHelpers/IShowWarningMessage.cs | 32 + .../ViewHelpers/ITypeSigCreator.cs | 34 + .../ViewHelpers/OpenAssembly.cs | 46 + .../dnSpy.AsmEditor/ViewHelpers/OpenFile.cs | 60 + .../ViewHelpers/OpenPublicKeyFile.cs | 67 + .../ViewHelpers/ShowWarningMessage.cs | 43 + .../ViewHelpers/TypeSigCreator.cs | 51 + .../dnSpy.AsmEditor/dnSpy.AsmEditor.csproj | 841 ++ Plugins/dnSpy.BamlDecompiler/Annotations.cs | 9 + .../dnSpy.BamlDecompiler/Baml/BamlContext.cs | 104 + .../dnSpy.BamlDecompiler/Baml/BamlDocument.cs | 39 + Plugins/dnSpy.BamlDecompiler/Baml/BamlNode.cs | 178 + .../dnSpy.BamlDecompiler/Baml/BamlReader.cs | 262 + .../dnSpy.BamlDecompiler/Baml/BamlRecords.cs | 1130 +++ .../dnSpy.BamlDecompiler/Baml/BamlWriter.cs | 67 + .../dnSpy.BamlDecompiler/Baml/KnownMembers.cs | 297 + .../dnSpy.BamlDecompiler/Baml/KnownThings.cs | 101 + .../Baml/KnownThings.g.cs | 1319 ++++ .../Baml/KnownThings.gen.cs | 279 + .../dnSpy.BamlDecompiler/Baml/KnownTypes.cs | 788 ++ .../dnSpy.BamlDecompiler/BamlDecompiler.cs | 41 + .../dnSpy.BamlDecompiler/BamlDisassembler.cs | 592 ++ Plugins/dnSpy.BamlDecompiler/BamlElement.cs | 71 + .../BamlResourceElementNode.cs | 133 + .../BamlResourceNodeCreator.cs | 58 + Plugins/dnSpy.BamlDecompiler/BamlSettings.cs | 145 + .../dnSpy.BamlDecompiler/BamlSettings.xaml | 12 + .../BamlTabSaverCreator.cs | 155 + .../BamlToolTipContentCreator.cs | 53 + .../Blocks/ConstructorParametersHandler.cs | 41 + .../Handlers/Blocks/DocumentHandler.cs | 40 + .../Handlers/Blocks/ElementHandler.cs | 59 + .../Handlers/Blocks/KeyElementStartHandler.cs | 51 + .../Handlers/Blocks/PropertyArrayHandler.cs | 49 + .../Handlers/Blocks/PropertyComplexHandler.cs | 49 + .../Blocks/PropertyDictionaryHandler.cs | 49 + .../Handlers/Blocks/PropertyListHandler.cs | 49 + .../Handlers/Records/AssemblyInfoHandler.cs | 35 + .../Handlers/Records/AttributeInfoHandler.cs | 35 + .../Handlers/Records/ConnectionIdHandler.cs | 39 + .../ConstructorParameterTypeHandler.cs | 50 + .../Records/ContentPropertyHandler.cs | 38 + .../Handlers/Records/DefAttributeHandler.cs | 41 + .../Records/DefAttributeKeyStringHandler.cs | 51 + .../Records/DefAttributeKeyTypeHandler.cs | 58 + .../Records/DeferableContentStartHandler.cs | 40 + .../Records/LineNumberAndPositionHandler.cs | 35 + .../Handlers/Records/LinePositionHandler.cs | 35 + .../Handlers/Records/LiteralContentHandler.cs | 44 + .../Records/OptimizedStaticResourceHandler.cs | 108 + .../Handlers/Records/PIMappingHandler.cs | 35 + .../PresentationOptionsAttributeHandler.cs | 42 + .../Handlers/Records/PropertyCustomHandler.cs | 162 + .../Handlers/Records/PropertyHandler.cs | 46 + .../Records/PropertyTypeReferenceHandler.cs | 58 + .../Records/PropertyWithConverterHandler.cs | 31 + .../Records/PropertyWithExtensionHandler.cs | 103 + .../PropertyWithStaticResourceIdHandler.cs | 67 + .../Handlers/Records/TextHandler.cs | 53 + .../Records/TextWithConverterHandler.cs | 31 + .../Handlers/Records/TypeInfoHandler.cs | 45 + .../Handlers/Records/XmlnsPropertyHandler.cs | 72 + Plugins/dnSpy.BamlDecompiler/IHandlers.cs | 69 + Plugins/dnSpy.BamlDecompiler/IRewritePass.cs | 29 + .../dnSpy.BamlDecompiler/Images/XamlFile.png | Bin 0 -> 256 bytes Plugins/dnSpy.BamlDecompiler/MenuCommands.cs | 59 + Plugins/dnSpy.BamlDecompiler/Plugin.cs | 50 + .../Properties/AssemblyInfo.cs | 14 + ...dnSpy.BamlDecompiler.Resources.Designer.cs | 198 + .../dnSpy.BamlDecompiler.Resources.resx | 165 + .../dnSpy.BamlDecompiler.Resources.ru.resx | 165 + .../dnSpy.BamlDecompiler.Resources.zh-CN.resx | 165 + .../Rewrite/AttributeRewritePass.cs | 72 + .../Rewrite/ConnectionIdRewritePass.cs | 233 + .../Rewrite/DocumentRewritePass.cs | 44 + .../Rewrite/MarkupExtensionRewritePass.cs | 175 + .../Rewrite/XClassRewritePass.cs | 62 + .../dnSpy.BamlDecompiler/Xaml/NamespaceMap.cs | 47 + .../Xaml/XamlExtension.cs | 82 + .../Xaml/XamlPathDeserializer.cs | 193 + .../dnSpy.BamlDecompiler/Xaml/XamlProperty.cs | 96 + .../Xaml/XamlResourceKey.cs | 98 + Plugins/dnSpy.BamlDecompiler/Xaml/XamlType.cs | 102 + .../dnSpy.BamlDecompiler/Xaml/XamlUtils.cs | 74 + Plugins/dnSpy.BamlDecompiler/XamlContext.cs | 196 + .../dnSpy.BamlDecompiler/XamlDecompiler.cs | 62 + .../dnSpy.BamlDecompiler/XmlnsDictionary.cs | 134 + .../dnSpy.BamlDecompiler.csproj | 183 + .../dnSpy.Debugger/dnSpy.Debugger/AppMenus.cs | 26 + .../dnSpy.Debugger/Breakpoints/Breakpoint.cs | 80 + .../Breakpoints/BreakpointColumnConverter.cs | 61 + .../Breakpoints/BreakpointContext.cs | 65 + .../Breakpoints/BreakpointListSettings.cs | 198 + .../Breakpoints/BreakpointManager.cs | 409 + .../Breakpoints/BreakpointPrinter.cs | 177 + .../Breakpoints/BreakpointSettings.cs | 177 + .../Breakpoints/BreakpointVM.cs | 123 + .../Breakpoints/BreakpointsContent.cs | 119 + .../Breakpoints/BreakpointsControl.xaml | 88 + .../Breakpoints/BreakpointsControl.xaml.cs | 44 + .../BreakpointsToolWindowContent.cs | 111 + .../Breakpoints/BreakpointsVM.cs | 243 + .../dnSpy.Debugger/Breakpoints/Commands.cs | 476 ++ .../Breakpoints/DebugEventBreakpoint.cs | 30 + .../Breakpoints/ILCodeBreakpoint.cs | 129 + .../dnSpy.Debugger/CachedOutput.cs | 194 + .../CallStack/CallStackContent.cs | 116 + .../CallStack/CallStackControl.xaml | 66 + .../CallStack/CallStackControl.xaml.cs | 48 + .../CallStackFrameColumnConverter.cs | 64 + .../CallStack/CallStackFrameVM.cs | 198 + .../CallStack/CallStackSettings.cs | 207 + .../CallStack/CallStackToolWindowContent.cs | 114 + .../dnSpy.Debugger/CallStack/CallStackVM.cs | 281 + .../dnSpy.Debugger/CallStack/Commands.cs | 496 ++ .../dnSpy.Debugger/CallStack/FrameUtils.cs | 95 + .../CallStack/StackFrameLine.cs | 116 + .../CallStack/StackFrameManager.cs | 319 + .../CallStack/VMPropertyChangedEventArgs.cs | 33 + .../dnSpy.Debugger/CodeMappings.cs | 166 + .../Converters/ImageConverter.cs | 51 + .../dnSpy.Debugger/DebugCommands.cs | 635 ++ .../dnSpy.Debugger/DebugManager.cs | 1438 ++++ .../dnSpy.Debugger/DebugManagerCommands.cs | 52 + .../dnSpy.Debugger/DebugOutputUtils.cs | 109 + .../dnSpy.Debugger/DebugRoutedCommands.cs | 63 + .../dnSpy.Debugger/DebugUtils.cs | 93 + .../DebuggedProcessRunningNotifier.cs | 101 + .../dnSpy.Debugger/DebuggerAppSettingsTab.cs | 102 + .../dnSpy.Debugger/DebuggerColors.cs | 54 + .../dnSpy.Debugger/DebuggerSettings.cs | 430 + .../Dialogs/AttachProcessDlg.xaml | 128 + .../Dialogs/AttachProcessDlg.xaml.cs | 85 + .../dnSpy.Debugger/Dialogs/AttachProcessVM.cs | 168 + .../Dialogs/DebugCoreCLRDlg.xaml | 94 + .../Dialogs/DebugCoreCLRDlg.xaml.cs | 50 + .../dnSpy.Debugger/Dialogs/DebugCoreCLRVM.cs | 245 + .../Dialogs/DebugProcessDlg.xaml | 80 + .../Dialogs/DebugProcessDlg.xaml.cs | 50 + .../dnSpy.Debugger/Dialogs/DebugProcessVM.cs | 174 + .../Dialogs/ManagedProcessesFinder.cs | 141 + .../Dialogs/ProcessColumnConverter.cs | 66 + .../dnSpy.Debugger/Dialogs/ProcessContext.cs | 28 + .../dnSpy.Debugger/Dialogs/ProcessPrinter.cs | 91 + .../dnSpy.Debugger/Dialogs/ProcessVM.cs | 84 + .../dnSpy.Debugger/EvalUtils.cs | 114 + .../dnSpy.Debugger/Exceptions/ClickFocusAP.cs | 66 + .../dnSpy.Debugger/Exceptions/Commands.cs | 379 + .../Exceptions/DefaultExceptionSettings.cs | 480 ++ .../Exceptions/ExceptionColumnConverter.cs | 47 + .../Exceptions/ExceptionControl.xaml | 100 + .../Exceptions/ExceptionControl.xaml.cs | 36 + .../Exceptions/ExceptionInfo.cs | 86 + .../Exceptions/ExceptionInfoKey.cs | 57 + .../Exceptions/ExceptionListSettings.cs | 165 + .../Exceptions/ExceptionManager.cs | 226 + .../Exceptions/ExceptionPrinter.cs | 61 + .../Exceptions/ExceptionState.cs | 45 + .../Exceptions/ExceptionType.cs | 27 + .../dnSpy.Debugger/Exceptions/ExceptionVM.cs | 74 + .../Exceptions/ExceptionsContent.cs | 97 + .../Exceptions/ExceptionsToolWindowContent.cs | 100 + .../dnSpy.Debugger/Exceptions/ExceptionsVM.cs | 314 + .../Exceptions/IGetNewExceptionName.cs | 46 + .../Exceptions/ISelectedItemsProvider.cs | 39 + .../dnSpy.Debugger/ILoadBeforeDebug.cs | 27 + .../dnSpy.Debugger/IMModules/ClassLoader.cs | 236 + .../dnSpy.Debugger/IMModules/Commands.cs | 120 + .../IMModules/CorModuleDefFile.cs | 140 + .../IMModules/InMemoryModuleManager.cs | 451 ++ .../dnSpy.Debugger/IMModules/LastValidRids.cs | 45 + .../IMModules/LoadEverythingDlg.xaml | 54 + .../IMModules/LoadEverythingDlg.xaml.cs | 72 + .../IMModules/LoadEverythingVM.cs | 131 + .../IMModules/MemoryModuleDefFile.cs | 168 + .../IMModules/TreeViewUpdater.cs | 193 + .../dnSpy.Debugger/ISerializedDnModule.cs | 39 + .../dnSpy.Debugger/Images/Add.png | Bin 0 -> 139 bytes .../dnSpy.Debugger/Images/AssemblyExe.png | Bin 0 -> 240 bytes .../dnSpy.Debugger/Images/AssemblyModule.png | Bin 0 -> 133 bytes .../dnSpy.Debugger/Images/Break.png | Bin 0 -> 131 bytes .../dnSpy.Debugger/Images/Breakpoint.png | Bin 0 -> 230 bytes .../dnSpy.Debugger/Images/BreakpointMenu.png | Bin 0 -> 238 bytes .../Images/BreakpointsWindow.png | Bin 0 -> 231 bytes .../dnSpy.Debugger/Images/CallStackWindow.png | Bin 0 -> 170 bytes .../Images/ContinueDebugging.png | Bin 0 -> 233 bytes .../dnSpy.Debugger/Images/Copy.png | Bin 0 -> 194 bytes .../dnSpy.Debugger/Images/CurrentLine.png | Bin 0 -> 217 bytes .../Images/CurrentLineToolBar.png | Bin 0 -> 255 bytes .../dnSpy.Debugger/Images/Cursor.png | Bin 0 -> 205 bytes .../dnSpy.Debugger/Images/Delete.png | Bin 0 -> 523 bytes .../Images/DeleteAllBreakpoints.png | Bin 0 -> 373 bytes .../Images/DisableAllBreakpoints.png | Bin 0 -> 518 bytes .../Images/DisableEnableBreakpoint.png | Bin 0 -> 256 bytes .../Images/DisabledBreakpoint.png | Bin 0 -> 365 bytes .../Images/DisassemblyWindow.png | Bin 0 -> 184 bytes .../DraggedCurrentInstructionPointer.png | Bin 0 -> 148 bytes .../Images/EnableAllBreakpoints.png | Bin 0 -> 479 bytes .../dnSpy.Debugger/Images/EnumValue.png | Bin 0 -> 259 bytes .../Images/EnumValueCompilerControlled.png | Bin 0 -> 209 bytes .../Images/EnumValueInternal.png | Bin 0 -> 258 bytes .../Images/EnumValuePrivate.png | Bin 0 -> 204 bytes .../Images/EnumValueProtected.png | Bin 0 -> 263 bytes .../Images/EnumValueProtectedInternal.png | Bin 0 -> 201 bytes .../dnSpy.Debugger/Images/Exception.png | Bin 0 -> 138 bytes .../Images/ExceptionSettings.png | Bin 0 -> 350 bytes .../dnSpy.Debugger/Images/Field.png | Bin 0 -> 216 bytes .../Images/FieldCompilerControlled.png | Bin 0 -> 253 bytes .../dnSpy.Debugger/Images/FieldInternal.png | Bin 0 -> 292 bytes .../dnSpy.Debugger/Images/FieldPrivate.png | Bin 0 -> 245 bytes .../dnSpy.Debugger/Images/FieldProtected.png | Bin 0 -> 300 bytes .../Images/FieldProtectedInternal.png | Bin 0 -> 246 bytes .../dnSpy.Debugger/Images/FieldReadOnly.png | Bin 0 -> 285 bytes .../FieldReadOnlyCompilerControlled.png | Bin 0 -> 340 bytes .../Images/FieldReadOnlyInternal.png | Bin 0 -> 376 bytes .../Images/FieldReadOnlyPrivate.png | Bin 0 -> 330 bytes .../Images/FieldReadOnlyProtected.png | Bin 0 -> 385 bytes .../Images/FieldReadOnlyProtectedInternal.png | Bin 0 -> 324 bytes .../dnSpy.Debugger/Images/Filter.png | Bin 0 -> 280 bytes .../Images/GenericParameter.png | Bin 0 -> 222 bytes .../dnSpy.Debugger/Images/GoToSourceCode.png | Bin 0 -> 186 bytes .../dnSpy.Debugger/Images/Literal.png | Bin 0 -> 165 bytes .../Images/LiteralCompilerControlled.png | Bin 0 -> 392 bytes .../dnSpy.Debugger/Images/LiteralInternal.png | Bin 0 -> 240 bytes .../dnSpy.Debugger/Images/LiteralPrivate.png | Bin 0 -> 259 bytes .../Images/LiteralProtected.png | Bin 0 -> 310 bytes .../Images/LiteralProtectedInternal.png | Bin 0 -> 183 bytes .../dnSpy.Debugger/Images/LocalsWindow.png | Bin 0 -> 370 bytes .../dnSpy.Debugger/Images/MemoryWindow.png | Bin 0 -> 155 bytes .../dnSpy.Debugger/Images/ModulesWindow.png | Bin 0 -> 145 bytes .../dnSpy.Debugger/Images/OneLevelUp.png | Bin 0 -> 301 bytes .../dnSpy.Debugger/Images/Process.png | Bin 0 -> 600 bytes .../dnSpy.Debugger/Images/Property.png | Bin 0 -> 316 bytes .../Images/PropertyCompilerControlled.png | Bin 0 -> 500 bytes .../Images/PropertyInternal.png | Bin 0 -> 283 bytes .../dnSpy.Debugger/Images/PropertyPrivate.png | Bin 0 -> 364 bytes .../Images/PropertyProtected.png | Bin 0 -> 298 bytes .../Images/PropertyProtectedInternal.png | Bin 0 -> 348 bytes .../dnSpy.Debugger/Images/QuestionMark.png | Bin 0 -> 207 bytes .../dnSpy.Debugger/Images/Refresh.png | Bin 0 -> 492 bytes .../dnSpy.Debugger/Images/RemoveCommand.png | Bin 0 -> 123 bytes .../dnSpy.Debugger/Images/RestartProcess.png | Bin 0 -> 305 bytes .../dnSpy.Debugger/Images/Save.png | Bin 0 -> 218 bytes .../dnSpy.Debugger/Images/Select.png | Bin 0 -> 304 bytes .../Images/SelectedReturnLine.png | Bin 0 -> 330 bytes .../Images/SetNextStatement.png | Bin 0 -> 178 bytes .../dnSpy.Debugger/Images/StartDebugging.png | Bin 0 -> 233 bytes .../Images/StartWithoutDebugging.png | Bin 0 -> 231 bytes .../dnSpy.Debugger/Images/StaticProperty.png | Bin 0 -> 310 bytes .../StaticPropertyCompilerControlled.png | Bin 0 -> 428 bytes .../Images/StaticPropertyInternal.png | Bin 0 -> 391 bytes .../Images/StaticPropertyPrivate.png | Bin 0 -> 350 bytes .../Images/StaticPropertyProtected.png | Bin 0 -> 403 bytes .../StaticPropertyProtectedInternal.png | Bin 0 -> 343 bytes .../dnSpy.Debugger/Images/StatusError.png | Bin 0 -> 377 bytes .../dnSpy.Debugger/Images/StepInto.png | Bin 0 -> 287 bytes .../dnSpy.Debugger/Images/StepOut.png | Bin 0 -> 296 bytes .../dnSpy.Debugger/Images/StepOver.png | Bin 0 -> 408 bytes .../dnSpy.Debugger/Images/StopProcess.png | Bin 0 -> 122 bytes .../dnSpy.Debugger/Images/SuperTypes.png | Bin 0 -> 196 bytes .../dnSpy.Debugger/Images/SuperTypesOpen.png | Bin 0 -> 345 bytes .../dnSpy.Debugger/Images/Thread.png | Bin 0 -> 375 bytes .../Images/UndoCheckBoxList.png | Bin 0 -> 385 bytes .../dnSpy.Debugger/Images/VirtualProperty.png | Bin 0 -> 306 bytes .../VirtualPropertyCompilerControlled.png | Bin 0 -> 420 bytes .../Images/VirtualPropertyInternal.png | Bin 0 -> 380 bytes .../Images/VirtualPropertyPrivate.png | Bin 0 -> 337 bytes .../Images/VirtualPropertyProtected.png | Bin 0 -> 393 bytes .../VirtualPropertyProtectedInternal.png | Bin 0 -> 332 bytes .../dnSpy.Debugger/Images/Watch.png | Bin 0 -> 278 bytes .../dnSpy.Debugger/Locals/AskUser.cs | 51 + .../dnSpy.Debugger/Locals/Commands.cs | 710 ++ .../Locals/EditValueControl.xaml | 32 + .../Locals/EditValueControl.xaml.cs | 175 + .../Locals/LocalColumnConverter.cs | 51 + .../dnSpy.Debugger/Locals/LocalsContent.cs | 101 + .../dnSpy.Debugger/Locals/LocalsControl.xaml | 96 + .../Locals/LocalsControl.xaml.cs | 51 + .../dnSpy.Debugger/Locals/LocalsSettings.cs | 102 + .../Locals/LocalsToolWindowContent.cs | 114 + .../dnSpy.Debugger/Locals/LocalsVM.cs | 613 ++ .../Locals/MethodLocalProvider.cs | 87 + .../dnSpy.Debugger/Locals/ValueContext.cs | 113 + .../dnSpy.Debugger/Locals/ValuePrinter.cs | 63 + .../Locals/ValueStringParser.cs | 443 ++ .../dnSpy.Debugger/Locals/ValueVM.cs | 1823 +++++ .../dnSpy.Debugger/Logger/Commands.cs | 155 + .../dnSpy.Debugger/Logger/OutputLogger.cs | 316 + .../Logger/OutputLoggerSettings.cs | 177 + .../dnSpy.Debugger/MarkedTextLine.cs | 114 + .../dnSpy.Debugger/Memory/Commands.cs | 45 + .../dnSpy.Debugger/Memory/MemoryContent.cs | 109 + .../dnSpy.Debugger/Memory/MemoryControl.xaml | 37 + .../Memory/MemoryControl.xaml.cs | 38 + .../Memory/MemoryToolWindowContent.cs | 179 + .../dnSpy.Debugger/Memory/MemoryVM.cs | 160 + .../Memory/MemoryWindowManager.cs | 94 + .../Memory/MemoryWindowsHelper.cs | 42 + .../dnSpy.Debugger/Memory/ProcessHexStream.cs | 71 + .../dnSpy.Debugger/MenuItemCommandProxy.cs | 50 + .../dnSpy.Debugger/ModuleLoader.cs | 222 + .../dnSpy.Debugger/Modules/Commands.cs | 627 ++ .../Modules/ModuleColumnConverter.cs | 71 + .../dnSpy.Debugger/Modules/ModulePrinter.cs | 112 + .../dnSpy.Debugger/Modules/ModuleVM.cs | 174 + .../dnSpy.Debugger/Modules/ModulesContent.cs | 117 + .../Modules/ModulesControl.xaml | 136 + .../Modules/ModulesControl.xaml.cs | 44 + .../Modules/ModulesToolWindowContent.cs | 114 + .../dnSpy.Debugger/Modules/ModulesVM.cs | 202 + .../dnSpy.Debugger/Modules/PEFilesSaver.cs | 139 + .../dnSpy.Debugger/NativeMethods.cs | 68 + .../dnSpy.Debugger/OutputConverter.cs | 85 + .../dnSpy.Debugger/OutputWriterConverter.cs | 40 + .../dnSpy.Debugger/dnSpy.Debugger/Plugin.cs | 42 + .../dnSpy.Debugger/ProcessMemoryUtils.cs | 36 + .../dnSpy.Debugger/Properties/AssemblyInfo.cs | 14 + .../dnSpy.Debugger.Resources.Designer.cs | 3489 +++++++++ .../Properties/dnSpy.Debugger.Resources.resx | 1278 +++ .../dnSpy.Debugger.Resources.ru.resx | 1227 +++ .../dnSpy.Debugger.Resources.zh-CN.resx | 1227 +++ .../Scripting/AnyEventBreakpoint.cs | 111 + .../Scripting/DebugEventContext.cs | 325 + .../dnSpy.Debugger/Scripting/Debugger.cs | 1403 ++++ .../Scripting/DebuggerAppDomain.cs | 624 ++ .../Scripting/DebuggerAssembly.cs | 101 + .../dnSpy.Debugger/Scripting/DebuggerClass.cs | 598 ++ .../dnSpy.Debugger/Scripting/DebuggerCode.cs | 137 + .../dnSpy.Debugger/Scripting/DebuggerEvent.cs | 194 + .../dnSpy.Debugger/Scripting/DebuggerField.cs | 215 + .../Scripting/DebuggerMethod.cs | 347 + .../Scripting/DebuggerModule.cs | 672 ++ .../Scripting/DebuggerProperty.cs | 179 + .../Scripting/DebuggerThread.cs | 389 + .../dnSpy.Debugger/Scripting/DebuggerType.cs | 736 ++ .../dnSpy.Debugger/Scripting/DebuggerValue.cs | 728 ++ .../dnSpy.Debugger/Scripting/Eval.cs | 1094 +++ .../Scripting/EventBreakpoint.cs | 121 + .../Scripting/IDnBreakpointHolder.cs | 36 + .../dnSpy.Debugger/Scripting/ILBreakpoint.cs | 146 + .../Scripting/NativeBreakpoint.cs | 162 + .../dnSpy.Debugger/Scripting/StackChain.cs | 149 + .../dnSpy.Debugger/Scripting/StackFrame.cs | 430 + .../dnSpy.Debugger/Scripting/TypeComparer.cs | 137 + .../dnSpy.Debugger/Scripting/Utils.cs | 321 + .../SerializedDnModuleCreator.cs | 52 + .../dnSpy.Debugger/SerializedDnToken.cs | 65 + .../dnSpy.Debugger/TheDebugger.cs | 244 + .../Themes/wpf.styles.templates.xaml | 98 + .../dnSpy.Debugger/Threads/Commands.cs | 318 + .../Threads/ThreadColumnConverter.cs | 93 + .../dnSpy.Debugger/Threads/ThreadPrinter.cs | 192 + .../dnSpy.Debugger/Threads/ThreadVM.cs | 382 + .../dnSpy.Debugger/Threads/ThreadsContent.cs | 117 + .../Threads/ThreadsControl.xaml | 143 + .../Threads/ThreadsControl.xaml.cs | 44 + .../Threads/ThreadsToolWindowContent.cs | 114 + .../dnSpy.Debugger/Threads/ThreadsVM.cs | 213 + .../WpfDebugMessageDispatcher.cs | 128 + .../dnSpy.Debugger/dnSpy.Debugger.csproj | 439 ++ Plugins/dnSpy.Debugger/dndbg/COM/CorDebug.cs | 2180 ++++++ Plugins/dnSpy.Debugger/dndbg/COM/MetaData.cs | 318 + Plugins/dnSpy.Debugger/dndbg/COM/MetaHost.cs | 83 + .../dndbg/DotNet/CorAssemblyDef.cs | 65 + .../dndbg/DotNet/CorAssemblyRef.cs | 62 + .../dndbg/DotNet/CorDeclSecurity.cs | 69 + .../dndbg/DotNet/CorEventDef.cs | 109 + .../dndbg/DotNet/CorExportedType.cs | 67 + .../dndbg/DotNet/CorFieldDef.cs | 167 + .../dnSpy.Debugger/dndbg/DotNet/CorFileDef.cs | 56 + .../dndbg/DotNet/CorGenericParam.cs | 126 + .../dndbg/DotNet/CorGenericParamConstraint.cs | 51 + .../dndbg/DotNet/CorInterfaceImpl.cs | 50 + .../dndbg/DotNet/CorManifestResource.cs | 59 + .../dndbg/DotNet/CorMemberRef.cs | 75 + .../dndbg/DotNet/CorMethodDef.cs | 243 + .../dndbg/DotNet/CorMethodSpec.cs | 55 + .../dndbg/DotNet/CorModuleDef.cs | 1397 ++++ .../dndbg/DotNet/CorModuleRef.cs | 55 + .../dndbg/DotNet/CorParamDef.cs | 116 + .../dndbg/DotNet/CorPropertyDef.cs | 127 + .../dndbg/DotNet/CorStandAloneSig.cs | 53 + .../dnSpy.Debugger/dndbg/DotNet/CorTypeDef.cs | 463 ++ .../dnSpy.Debugger/dndbg/DotNet/CorTypeRef.cs | 69 + .../dndbg/DotNet/CorTypeSpec.cs | 55 + .../dndbg/DotNet/ICorMDTokenProvider.cs | 40 + .../dndbg/DotNet/ICorModuleDefHelper.cs | 83 + .../dndbg/DotNet/IProcessReader.cs | 36 + .../dndbg/DotNet/ProcessBinaryReader.cs | 207 + .../dndbg/DotNet/TypeUpdatedEventArgs.cs | 49 + Plugins/dnSpy.Debugger/dndbg/DotNet/Utils.cs | 59 + .../dndbg/Engine/AttachProcessOptions.cs | 98 + .../dndbg/Engine/BreakProcessHelper.cs | 261 + .../dndbg/Engine/BreakProcessKind.cs | 68 + .../dndbg/Engine/BreakpointList.cs | 54 + .../dnSpy.Debugger/dndbg/Engine/COMObject.cs | 62 + .../dndbg/Engine/CorAppDomain.cs | 267 + .../dndbg/Engine/CorAssembly.cs | 186 + .../dnSpy.Debugger/dndbg/Engine/CorChain.cs | 191 + .../dnSpy.Debugger/dndbg/Engine/CorClass.cs | 483 ++ .../dnSpy.Debugger/dndbg/Engine/CorCode.cs | 176 + .../dndbg/Engine/CorDebugExtensions.cs | 31 + .../dndbg/Engine/CorDebugManagedCallback.cs | 178 + .../dnSpy.Debugger/dndbg/Engine/CorEval.cs | 255 + .../dnSpy.Debugger/dndbg/Engine/CorEvent.cs | 158 + .../Engine/CorExceptionObjectStackFrame.cs | 36 + .../dnSpy.Debugger/dndbg/Engine/CorField.cs | 130 + .../dnSpy.Debugger/dndbg/Engine/CorFrame.cs | 614 ++ .../dndbg/Engine/CorFunction.cs | 297 + .../dndbg/Engine/CorFunctionBreakpoint.cs | 94 + Plugins/dnSpy.Debugger/dndbg/Engine/CorMDA.cs | 140 + .../dnSpy.Debugger/dndbg/Engine/CorModule.cs | 395 + .../dndbg/Engine/CorModuleDefHelper.cs | 216 + .../dndbg/Engine/CorOverride.cs | 63 + .../dnSpy.Debugger/dndbg/Engine/CorProcess.cs | 372 + .../dndbg/Engine/CorProcessReader.cs | 43 + .../dndbg/Engine/CorProperty.cs | 144 + .../dnSpy.Debugger/dndbg/Engine/CorStepper.cs | 112 + .../dnSpy.Debugger/dndbg/Engine/CorThread.cs | 334 + .../dnSpy.Debugger/dndbg/Engine/CorType.cs | 746 ++ .../dnSpy.Debugger/dndbg/Engine/CorValue.cs | 785 ++ .../dndbg/Engine/CorValueHolder.cs | 113 + .../dndbg/Engine/CorValueReader.cs | 314 + .../dndbg/Engine/CordbgErrors.cs | 42 + .../dndbg/Engine/CoreCLRHelper.cs | 293 + .../dndbg/Engine/DebugCallbackEventArgs.cs | 960 +++ .../dndbg/Engine/DebugEventBreakpointList.cs | 38 + .../dndbg/Engine/DebugOptions.cs | 205 + .../dndbg/Engine/DebugProcessOptions.cs | 152 + .../dndbg/Engine/DebuggeeVersionDetector.cs | 68 + .../dndbg/Engine/DebuggerCollection.cs | 89 + .../dndbg/Engine/DebuggerEventArgs.cs | 57 + .../dndbg/Engine/DebuggerPauseState.cs | 155 + .../dndbg/Engine/DebuggerProcessState.cs | 47 + .../dndbg/Engine/DebuggerState.cs | 110 + .../Engine/DisableSystemDebuggerDetection.cs | 113 + .../dndbg/Engine/DnAnyDebugEventBreakpoint.cs | 56 + .../dndbg/Engine/DnAppDomain.cs | 183 + .../dnSpy.Debugger/dndbg/Engine/DnAssembly.cs | 197 + .../dndbg/Engine/DnBreakpoint.cs | 57 + .../dndbg/Engine/DnCodeBreakpoint.cs | 142 + .../dndbg/Engine/DnDebugEventBreakpoint.cs | 109 + .../dnSpy.Debugger/dndbg/Engine/DnDebugger.cs | 1711 ++++ Plugins/dnSpy.Debugger/dndbg/Engine/DnEval.cs | 360 + .../dndbg/Engine/DnILCodeBreakpoint.cs | 55 + .../dnSpy.Debugger/dndbg/Engine/DnModule.cs | 204 + .../dndbg/Engine/DnNativeCodeBreakpoint.cs | 60 + .../dnSpy.Debugger/dndbg/Engine/DnProcess.cs | 321 + .../dnSpy.Debugger/dndbg/Engine/DnThread.cs | 138 + .../dndbg/Engine/DndbgSignatureReader.cs | 158 + .../dndbg/Engine/ECallManager.cs | 422 + .../dndbg/Engine/IDebugMessageDispatcher.cs | 47 + .../dnSpy.Debugger/dndbg/Engine/ILFrameIP.cs | 98 + .../dndbg/Engine/IdentifierEscaper.cs | 94 + Plugins/dnSpy.Debugger/dndbg/Engine/MDAPI.cs | 1715 ++++ .../dndbg/Engine/MetaDataUtils.cs | 578 ++ .../dndbg/Engine/NativeMethods.cs | 66 + .../dndbg/Engine/ProcessCreationFlags.cs | 63 + .../dndbg/Engine/SerializedDnModule.cs | 233 + .../dnSpy.Debugger/dndbg/Engine/StepRange.cs | 45 + .../dndbg/Engine/TypeComparer.cs | 125 + .../dndbg/Engine/TypePrinter.cs | 2075 +++++ .../dndbg/Engine/TypePrinterUtils.cs | 110 + Plugins/dnSpy.Debugger/dndbg/Engine/Utils.cs | 128 + .../dndbg/Properties/AssemblyInfo.cs | 14 + Plugins/dnSpy.Debugger/dndbg/dndbg.csproj | 167 + .../CSharp/CSharpContent.cs | 51 + .../CSharp/CSharpControlVM.cs | 114 + .../CSharp/CSharpToolWindowContent.cs | 84 + .../CSharpInteractive.rsp | 23 + .../Common/CachedWriter.cs | 68 + .../Common/ClearCommand.cs | 36 + .../dnSpy.Scripting.Roslyn/Common/Commands.cs | 116 + .../Common/HelpCommand.cs | 72 + .../Common/IScriptCommand.cs | 44 + .../Common/IScriptGlobalsHelper.cs | 38 + .../Common/PrintOptionsImpl.cs | 73 + .../Common/ResetCommand.cs | 37 + .../Common/RespFileUtils.cs | 49 + .../Common/ResponseFileReader.cs | 53 + .../Common/ScriptContent.cs | 84 + .../Common/ScriptControl.xaml | 70 + .../Common/ScriptControl.xaml.cs | 30 + .../Common/ScriptControlVM.cs | 559 ++ .../Common/ScriptGlobals.cs | 116 + .../Common/ScriptToolWindowContent.cs | 97 + .../Converters/ImageConverter.cs | 51 + .../Images/ArrowDown.png | Bin 0 -> 189 bytes .../dnSpy.Scripting.Roslyn/Images/ArrowUp.png | Bin 0 -> 276 bytes .../Images/CSInteractiveWindow.png | Bin 0 -> 197 bytes .../Images/ClearWindowContent.png | Bin 0 -> 320 bytes .../dnSpy.Scripting.Roslyn/Images/Copy.png | Bin 0 -> 194 bytes .../Images/CopyItem.png | Bin 0 -> 194 bytes Plugins/dnSpy.Scripting.Roslyn/Images/Cut.png | Bin 0 -> 319 bytes .../dnSpy.Scripting.Roslyn/Images/Paste.png | Bin 0 -> 265 bytes .../dnSpy.Scripting.Roslyn/Images/Reset.png | Bin 0 -> 305 bytes .../Images/VBInteractiveWindow.png | Bin 0 -> 193 bytes Plugins/dnSpy.Scripting.Roslyn/Plugin.cs | 57 + .../Properties/AssemblyInfo.cs | 14 + ...Spy.Scripting.Roslyn.Resources.Designer.cs | 513 ++ .../dnSpy.Scripting.Roslyn.Resources.resx | 270 + .../dnSpy.Scripting.Roslyn.Resources.ru.resx | 264 + ...nSpy.Scripting.Roslyn.Resources.zh-CN.resx | 264 + .../VisualBasic/VisualBasicContent.cs | 51 + .../VisualBasic/VisualBasicControlVM.cs | 111 + .../VisualBasicToolWindowContent.cs | 84 + .../VisualBasicInteractive.rsp | 24 + .../dnSpy.Scripting.Roslyn.csproj | 143 + Plugins/dnSpy.Scripting.Roslyn/project.json | 11 + README.md | 26 + dnSpy.sln | 216 + dnSpy.snk | Bin 0 -> 596 bytes dnSpy/dnSpy-x86/Program.cs | 29 + dnSpy/dnSpy-x86/Properties/AssemblyInfo.cs | 14 + dnSpy/dnSpy-x86/dnSpy-x86.csproj | 78 + dnSpy/dnSpy.Console/Program.cs | 796 ++ .../dnSpy.Console/Properties/AssemblyInfo.cs | 14 + .../dnSpy.Console.Resources.Designer.cs | 386 + .../Properties/dnSpy.Console.Resources.resx | 252 + .../dnSpy.Console.Resources.ru.resx | 252 + .../dnSpy.Console.Resources.zh-CN.resx | 252 + dnSpy/dnSpy.Console/dnSpy.Console.csproj | 97 + dnSpy/dnSpy.Contracts/App/AppDirectories.cs | 96 + .../App/IAppCommandLineArgs.cs | 99 + .../App/IAppCommandLineArgsHandler.cs | 36 + dnSpy/dnSpy.Contracts/App/IAppSettings.cs | 42 + dnSpy/dnSpy.Contracts/App/IAppStatusBar.cs | 41 + dnSpy/dnSpy.Contracts/App/IAppWindow.cs | 117 + dnSpy/dnSpy.Contracts/App/IDnSpyLoader.cs | 75 + .../dnSpy.Contracts/App/IMessageBoxManager.cs | 73 + dnSpy/dnSpy.Contracts/App/LoaderConstants.cs | 37 + dnSpy/dnSpy.Contracts/App/MsgBoxButton.cs | 39 + .../dnSpy.Contracts/Command/ICommandHolder.cs | 32 + .../Controls/CommandConstants.cs | 111 + dnSpy/dnSpy.Contracts/Controls/IFocusable.cs | 35 + .../Controls/IWpfCommandManager.cs | 49 + .../dnSpy.Contracts/Controls/IWpfCommands.cs | 64 + .../Controls/IWpfFocusChecker.cs | 33 + .../Controls/IWpfFocusManager.cs | 41 + .../Decompiler/ICodeMappings.cs | 103 + dnSpy/dnSpy.Contracts/Files/DnSpyFileInfo.cs | 92 + dnSpy/dnSpy.Contracts/Files/FileConstants.cs | 57 + dnSpy/dnSpy.Contracts/Files/FilenameKey.cs | 85 + dnSpy/dnSpy.Contracts/Files/IAnnotations.cs | 55 + .../dnSpy.Contracts/Files/IDnSpyDotNetFile.cs | 26 + dnSpy/dnSpy.Contracts/Files/IDnSpyFile.cs | 202 + .../Files/IDnSpyFileCreator.cs | 47 + .../Files/IDnSpyFilenameKey.cs | 26 + dnSpy/dnSpy.Contracts/Files/IDnSpyPEFile.cs | 26 + dnSpy/dnSpy.Contracts/Files/IFileManager.cs | 140 + .../Files/IFileManagerCreator.cs | 31 + .../Files/IFileManagerSettings.cs | 42 + .../Files/IMethodAnnotations.cs | 41 + .../NotifyFileCollectionChangedEventArgs.cs | 105 + .../Files/NotifyFileCollectionType.cs | 40 + .../Files/Tabs/FileModifiedEventArgs.cs | 40 + .../Files/Tabs/FileTabReferenceResult.cs | 56 + .../Files/Tabs/IAsyncFileTabContent.cs | 49 + .../Files/Tabs/IAsyncShowResult.cs | 43 + .../Files/Tabs/IFileListListener.cs | 82 + dnSpy/dnSpy.Contracts/Files/Tabs/IFileTab.cs | 151 + .../Files/Tabs/IFileTabContent.cs | 85 + .../Files/Tabs/IFileTabContentFactory.cs | 78 + .../Tabs/IFileTabContentFactoryContext.cs | 32 + .../Files/Tabs/IFileTabManager.cs | 153 + .../Files/Tabs/IFileTabManagerSettings.cs | 38 + .../Files/Tabs/IFileTabUIContext.cs | 94 + .../Files/Tabs/IFileTabUIContextCreator.cs | 59 + .../Files/Tabs/IFileTabUIContextLocator.cs | 47 + .../Files/Tabs/ILanguageTabContent.cs | 32 + .../Tabs/IReferenceFileTabContentCreator.cs | 62 + .../Files/Tabs/ISaveManager.cs | 45 + .../Files/Tabs/IShowContext.cs | 47 + dnSpy/dnSpy.Contracts/Files/Tabs/ITabSaver.cs | 40 + .../Files/Tabs/ITabSaverCreator.cs | 58 + .../Files/Tabs/ShowTabContentEventArgs.cs | 53 + .../Files/Tabs/TabConstants.cs | 96 + .../Files/Tabs/TextEditor/CodeReference.cs | 52 + .../Files/Tabs/TextEditor/IDecompileNode.cs | 61 + .../TextEditor/IDecompileNodeCollection.cs | 61 + .../Tabs/TextEditor/IDecompileNodeContext.cs | 68 + .../Files/Tabs/TextEditor/IDecompileSelf.cs | 35 + .../Files/Tabs/TextEditor/IIconBarCommand.cs | 39 + .../Tabs/TextEditor/IIconBarCommandContext.cs | 35 + .../Files/Tabs/TextEditor/IIconBarObject.cs | 39 + .../Files/Tabs/TextEditor/IMarkedTextLine.cs | 27 + .../Tabs/TextEditor/ITextEditorUIContext.cs | 134 + .../TextEditor/ITextEditorUIContextManager.cs | 46 + .../Files/Tabs/TextEditor/ITextLineObject.cs | 44 + .../Tabs/TextEditor/ITextLineObjectManager.cs | 57 + .../Files/Tabs/TextEditor/ITextMarker.cs | 175 + .../Tabs/TextEditor/ITextMarkerObject.cs | 33 + .../Tabs/TextEditor/TextEditorConstants.cs | 40 + .../TextEditorUIContextListenerEvent.cs | 44 + .../TextEditorUIContextManagerConstants.cs | 43 + .../TextEditor/TextLineObjectEventArgs.cs | 44 + .../TextLineObjectListModifiedEventArgs.cs | 47 + .../ToolTips/ICodeToolTipCreator.cs | 55 + .../TextEditor/ToolTips/ICodeToolTipWriter.cs | 50 + .../ToolTips/IToolTipContentCreator.cs | 59 + .../ToolTips/IToolTipContentCreatorContext.cs | 39 + .../Files/TreeView/FileTVConstants.cs | 243 + .../FileTreeNodeActivatedEventArgs.cs | 47 + .../TreeView/FileTreeNodeFilterResult.cs | 45 + .../Files/TreeView/FileTreeNodeGroupType.cs | 52 + .../Files/TreeView/FilterType.cs | 34 + .../Files/TreeView/IAssemblyFileNode.cs | 37 + .../Files/TreeView/IAssemblyReferenceNode.cs | 33 + .../Files/TreeView/IBaseTypeFolderNode.cs | 30 + .../Files/TreeView/IBaseTypeNode.cs | 33 + .../Files/TreeView/IDerivedTypeNode.cs | 33 + .../Files/TreeView/IDerivedTypesFolderNode.cs | 26 + .../Files/TreeView/IDnSpyFileNode.cs | 30 + .../Files/TreeView/IDnSpyFileNodeCreator.cs | 60 + .../Files/TreeView/IEventNode.cs | 40 + .../Files/TreeView/IFieldNode.cs | 33 + .../Files/TreeView/IFileTreeNodeCreator.cs | 119 + .../Files/TreeView/IFileTreeNodeData.cs | 128 + .../TreeView/IFileTreeNodeDataContext.cs | 93 + .../Files/TreeView/IFileTreeNodeDataFinder.cs | 59 + .../Files/TreeView/IFileTreeNodeFilter.cs | 215 + .../Files/TreeView/IFileTreeNodeGroups.cs | 34 + .../Files/TreeView/IFileTreeView.cs | 211 + .../Files/TreeView/IFileTreeViewCreator.cs | 32 + .../Files/TreeView/IFileTreeViewSettings.cs | 72 + .../Files/TreeView/IMessageNode.cs | 30 + .../Files/TreeView/IMethodNode.cs | 33 + .../Files/TreeView/IModuleFileNode.cs | 46 + .../Files/TreeView/IModuleReferenceNode.cs | 33 + .../Files/TreeView/INamespaceNode.cs | 39 + .../Files/TreeView/IPEFileNode.cs | 30 + .../Files/TreeView/IPropertyNode.cs | 40 + .../Files/TreeView/IReferencesFolderNode.cs | 41 + .../Files/TreeView/IResourcesFolderNode.cs | 26 + .../Files/TreeView/ITypeNode.cs | 68 + .../Files/TreeView/IUnknownFileNode.cs | 26 + .../Files/TreeView/MemberKind.cs | 36 + .../Files/TreeView/NodePathName.cs | 95 + .../TreeView/NotifyFileTreeViewCollection.cs | 40 + ...yFileTreeViewCollectionChangedEventArgs.cs | 80 + .../Resources/IBuiltInResourceElementNode.cs | 28 + .../Resources/IImageResourceElementNode.cs | 26 + .../TreeView/Resources/IImageResourceNode.cs | 26 + .../Resources/IResourceDataProvider.cs | 71 + .../Resources/IResourceElementNode.cs | 54 + .../Resources/IResourceElementSetNode.cs | 33 + .../Files/TreeView/Resources/IResourceNode.cs | 37 + .../Resources/IResourceNodeCreator.cs | 73 + .../Resources/IResourceNodeFactory.cs | 47 + ...zedImageListStreamerResourceElementNode.cs | 32 + .../ISerializedImageResourceElementNode.cs | 33 + .../ISerializedResourceElementNode.cs | 35 + .../Resources/IUnknownResourceNode.cs | 26 + .../IUnknownSerializedResourceElementNode.cs | 26 + .../TreeView/Resources/ImageListOptions.cs | 80 + .../Files/TreeView/Resources/ResourceData.cs | 57 + .../TreeView/Resources/ResourceDataType.cs | 35 + .../Highlighting/ISyntaxHighlightOutput.cs | 34 + .../dnSpy.Contracts/Images/BackgroundType.cs | 47 + .../Images/IDotNetImageManager.cs | 138 + dnSpy/dnSpy.Contracts/Images/IImageManager.cs | 47 + .../dnSpy.Contracts/Images/ImageReference.cs | 47 + .../Languages/BamlDecompilerOptions.cs | 67 + .../Languages/DecompilationContext.cs | 98 + .../Languages/DecompilationType.cs | 35 + .../Languages/DecompileAssemblyInfo.cs | 47 + .../Languages/DecompilePartialType.cs | 84 + .../Languages/DecompileTypeBase.cs | 50 + .../Languages/DecompilerOptionConstants.cs | 172 + .../Languages/IBamlDecompiler.cs | 41 + .../Languages/IDecompilerOption.cs | 52 + .../Languages/IDecompilerSettings.cs | 90 + .../Languages/IDecompilerSettingsTab.cs | 50 + .../IDecompilerSettingsTabCreator.cs | 33 + dnSpy/dnSpy.Contracts/Languages/ILanguage.cs | 251 + .../Languages/ILanguageCreator.cs | 33 + .../Languages/ILanguageManager.cs | 57 + .../Languages/ILanguageProvider.cs | 32 + .../Languages/ISimpleILPrinter.cs | 55 + .../Languages/LanguageConstants.cs | 82 + .../Languages/SimplePrinterFlags.cs | 51 + .../SyntaxHighlightOutputToTextOutput.cs | 105 + .../dnSpy.Contracts/Menus/CreatedMenuItem.cs | 51 + .../Menus/ExportMenuAttribute.cs | 54 + .../Menus/ExportMenuItemAttribute.cs | 72 + dnSpy/dnSpy.Contracts/Menus/GuidObject.cs | 59 + .../Menus/IContextMenuCreator.cs | 33 + .../Menus/IContextMenuInitializer.cs | 34 + .../Menus/IGuidObjectsCreator.cs | 35 + dnSpy/dnSpy.Contracts/Menus/IMenu.cs | 26 + dnSpy/dnSpy.Contracts/Menus/IMenuItem.cs | 82 + .../dnSpy.Contracts/Menus/IMenuItemContext.cs | 68 + .../dnSpy.Contracts/Menus/IMenuItemCreator.cs | 34 + .../Menus/IMenuItemMetadata.cs | 38 + dnSpy/dnSpy.Contracts/Menus/IMenuManager.cs | 59 + dnSpy/dnSpy.Contracts/Menus/IMenuMetadata.cs | 32 + dnSpy/dnSpy.Contracts/Menus/MenuConstants.cs | 463 ++ dnSpy/dnSpy.Contracts/Output/ICachedWriter.cs | 33 + .../dnSpy.Contracts/Output/IOutputManager.cs | 45 + .../dnSpy.Contracts/Output/IOutputTextPane.cs | 49 + dnSpy/dnSpy.Contracts/Output/IOutputWriter.cs | 41 + dnSpy/dnSpy.Contracts/Plugin/IAutoLoaded.cs | 85 + dnSpy/dnSpy.Contracts/Plugin/IPlugin.cs | 70 + dnSpy/dnSpy.Contracts/Plugin/PluginEvent.cs | 40 + dnSpy/dnSpy.Contracts/Plugin/PluginInfo.cs | 37 + .../Properties/AssemblyInfo.cs | 14 + .../Scripting/Debugger/AttachOptions.cs | 30 + .../dnSpy.Contracts/Scripting/Debugger/Box.cs | 38 + .../Scripting/Debugger/BreakProcessKind.cs | 68 + .../Scripting/Debugger/BreakpointKind.cs | 45 + .../Scripting/Debugger/ChainReason.cs | 83 + .../Scripting/Debugger/CodeChunkInfo.cs | 53 + .../Scripting/Debugger/CorElementType.cs | 67 + .../Scripting/Debugger/CoreCLRDebugOptions.cs | 52 + .../Scripting/Debugger/DebugEventKind.cs | 47 + .../Scripting/Debugger/DebugHandleType.cs | 38 + .../Scripting/Debugger/DebugOptions.cs | 45 + .../Scripting/Debugger/DebugStepReason.cs | 56 + .../Scripting/Debugger/DebuggerEventArgs.cs | 32 + .../Scripting/Debugger/DebuggerPauseState.cs | 216 + .../Debugger/DebuggerProcessState.cs | 50 + .../Debugger/ExceptionObjectStackFrame.cs | 59 + .../Scripting/Debugger/IAnyEventBreakpoint.cs | 26 + .../Scripting/Debugger/IAppDomain.cs | 360 + .../Scripting/Debugger/IBreakpoint.cs | 45 + .../Scripting/Debugger/ICodeBreakpoint.cs | 50 + .../Scripting/Debugger/IDebugEventContext.cs | 310 + .../Scripting/Debugger/IDebugger.cs | 1209 +++ .../Scripting/Debugger/IDebuggerAssembly.cs | 68 + .../Scripting/Debugger/IDebuggerClass.cs | 475 ++ .../Scripting/Debugger/IDebuggerCode.cs | 117 + .../Scripting/Debugger/IDebuggerEvent.cs | 101 + .../Scripting/Debugger/IDebuggerField.cs | 181 + .../Scripting/Debugger/IDebuggerMethod.cs | 336 + .../Scripting/Debugger/IDebuggerModule.cs | 813 ++ .../Scripting/Debugger/IDebuggerProperty.cs | 103 + .../Scripting/Debugger/IDebuggerThread.cs | 380 + .../Scripting/Debugger/IDebuggerType.cs | 598 ++ .../Scripting/Debugger/IDebuggerValue.cs | 623 ++ .../Scripting/Debugger/IEval.cs | 492 ++ .../Scripting/Debugger/IEventBreakpoint.cs | 30 + .../Scripting/Debugger/IILBreakpoint.cs | 26 + .../Scripting/Debugger/ILCodeKind.cs | 36 + .../Scripting/Debugger/ILFrameIP.cs | 109 + .../Scripting/Debugger/INativeBreakpoint.cs | 26 + .../Scripting/Debugger/IStackChain.cs | 82 + .../Scripting/Debugger/IStackFrame.cs | 428 + .../Scripting/Debugger/InternalFrameType.cs | 72 + .../Scripting/Debugger/MappingResult.cs | 55 + .../Scripting/Debugger/ModuleName.cs | 236 + .../Scripting/Debugger/ThreadState.cs | 36 + .../Scripting/Debugger/ThreadUserState.cs | 69 + .../Scripting/Debugger/TypeFormatFlags.cs | 58 + .../Scripting/Debugger/ValueResult.cs | 116 + .../Scripting/IOutputWritable.cs | 49 + .../Scripting/IOutputWriter.cs | 51 + .../Scripting/IServiceLocator.cs | 39 + .../Scripting/Roslyn/ICachedWriter.cs | 33 + .../Scripting/Roslyn/IPrintOptions.cs | 59 + .../Scripting/Roslyn/IScriptGlobals.cs | 294 + .../Scripting/Roslyn/ITextPrinter.cs | 143 + .../Scripting/Roslyn/MemberDisplayFormat.cs | 42 + .../Scripting/ScriptException.cs | 51 + dnSpy/dnSpy.Contracts/Search/BodyResult.cs | 41 + .../Search/FileSearcherOptions.cs | 81 + dnSpy/dnSpy.Contracts/Search/IFileSearcher.cs | 88 + .../Search/IFileSearcherCreator.cs | 32 + .../dnSpy.Contracts/Search/ISearchComparer.cs | 33 + dnSpy/dnSpy.Contracts/Search/ISearchResult.cs | 62 + .../Search/SearchResultEventArgs.cs | 42 + .../dnSpy.Contracts/Search/SearchTypeInfo.cs | 51 + .../Settings/Dialog/AppSettingsConstants.cs | 112 + .../Settings/Dialog/IAppRefreshSettings.cs | 48 + .../Dialog/IAppSettingsModifiedListener.cs | 58 + .../Settings/Dialog/IAppSettingsTab.cs | 48 + .../Settings/Dialog/IAppSettingsTabCreator.cs | 33 + .../Settings/Dialog/IDynamicAppSettingsTab.cs | 67 + .../Settings/Dialog/ISimpleAppOption.cs | 117 + .../Dialog/ISimpleAppOptionCreator.cs | 60 + .../Settings/ISettingsManager.cs | 58 + .../Settings/ISettingsSection.cs | 65 + .../Settings/ISettingsSectionCreator.cs | 70 + dnSpy/dnSpy.Contracts/Tabs/ITabContent.cs | 56 + dnSpy/dnSpy.Contracts/Tabs/ITabGroup.cs | 133 + .../dnSpy.Contracts/Tabs/ITabGroupManager.cs | 227 + dnSpy/dnSpy.Contracts/Tabs/ITabManager.cs | 50 + .../Tabs/ITabManagerCreator.cs | 31 + .../Tabs/TabContentAttachedEventArgs.cs | 47 + .../Tabs/TabContentVisibilityEvent.cs | 55 + .../TabGroupCollectionChangedEventArgs.cs | 47 + .../Tabs/TabGroupManagerOptions.cs | 85 + .../Tabs/TabGroupSelectedEventArgs.cs | 47 + .../Tabs/TabSelectedEventArgs.cs | 54 + .../TextEditor/ColorAndText.cs | 45 + .../TextEditor/ColorOffsetInfo.cs | 55 + .../dnSpy.Contracts/TextEditor/ILogEditor.cs | 63 + .../TextEditor/ILogEditorCreator.cs | 32 + .../TextEditor/ILogEditorUI.cs | 53 + .../TextEditor/IOutputColorWriter.cs | 58 + .../TextEditor/IReplCommandHandler.cs | 55 + .../TextEditor/IReplCommandInput.cs | 67 + .../dnSpy.Contracts/TextEditor/IReplEditor.cs | 104 + .../TextEditor/IReplEditorCreator.cs | 32 + .../TextEditor/IReplEditorUI.cs | 49 + .../TextEditor/ITextEditorSettings.cs | 58 + .../TextEditor/LogEditorOptions.cs | 65 + .../dnSpy.Contracts/TextEditor/OutputColor.cs | 151 + .../TextEditor/ReplEditorOptions.cs | 87 + .../TextEditor/TextEditorLocation.cs | 45 + dnSpy/dnSpy.Contracts/Themes/ColorType.cs | 605 ++ dnSpy/dnSpy.Contracts/Themes/ITheme.cs | 57 + dnSpy/dnSpy.Contracts/Themes/IThemeColor.cs | 63 + dnSpy/dnSpy.Contracts/Themes/IThemeManager.cs | 44 + .../Themes/ThemeChangedEventArgs.cs | 28 + .../dnSpy.Contracts/Themes/ThemeConstants.cs | 47 + .../ToolBars/ExportToolBarButtonAttribute.cs | 55 + .../ToolBars/ExportToolBarItemAttribute.cs | 52 + .../ToolBars/ExportToolBarObjectAttribute.cs | 34 + .../ToolBars/IToolBarButton.cs | 65 + .../ToolBars/IToolBarButtonMetadata.cs | 32 + .../dnSpy.Contracts/ToolBars/IToolBarItem.cs | 32 + .../ToolBars/IToolBarItemContext.cs | 32 + .../ToolBars/IToolBarItemMetadata.cs | 30 + .../ToolBars/IToolBarManager.cs | 38 + .../ToolBars/IToolBarObject.cs | 36 + .../ToolBars/IToolBarObjectMetadata.cs | 24 + .../ToolBars/IToolBarToggleButton.cs | 34 + .../ToolBars/ToolBarConstants.cs | 58 + .../ToolWindows/App/AppToolWindowConstants.cs | 64 + .../ToolWindows/App/AppToolWindowLocation.cs | 41 + .../App/IMainToolWindowContentCreator.cs | 41 + .../ToolWindows/App/IMainToolWindowManager.cs | 111 + .../ToolWindows/App/ToolWindowContentInfo.cs | 61 + .../ToolWindows/IToolWindowContent.cs | 69 + .../ToolWindows/IToolWindowGroup.cs | 78 + .../ToolWindows/IToolWindowGroupManager.cs | 215 + .../ToolWindows/IToolWindowManager.cs | 32 + .../ToolWindows/IToolWindowManagerCreator.cs | 31 + .../ToolWindowContentVisibilityEvent.cs | 55 + ...olWindowGroupCollectionChangedEventArgs.cs | 47 + .../ToolWindowGroupManagerOptions.cs | 77 + .../ToolWindowGroupSelectedEventArgs.cs | 47 + .../ToolWindowSelectedEventArgs.cs | 54 + .../dnSpy.Contracts/TreeView/IMDTokenNode.cs | 32 + dnSpy/dnSpy.Contracts/TreeView/ITreeNode.cs | 104 + .../dnSpy.Contracts/TreeView/ITreeNodeData.cs | 203 + .../TreeView/ITreeNodeDataCreator.cs | 68 + .../TreeView/ITreeNodeGroup.cs | 32 + dnSpy/dnSpy.Contracts/TreeView/ITreeView.cs | 111 + .../TreeView/ITreeViewListener.cs | 32 + .../TreeView/ITreeViewManager.cs | 43 + dnSpy/dnSpy.Contracts/TreeView/TVConstants.cs | 28 + .../TreeView/TVNodeRemovedEventArgs.cs | 47 + .../TreeView/TVSelectionChangedEventArgs.cs | 47 + .../TreeView/TreeNodeDataCreatorContext.cs | 38 + .../TreeView/TreeViewListenerEvent.cs | 30 + .../TreeView/TreeViewListenerEventArgs.cs | 47 + .../TreeView/TreeViewOptions.cs | 79 + dnSpy/dnSpy.Contracts/dnSpy.Contracts.csproj | 415 + .../AddressReference.cs | 55 + dnSpy/dnSpy.Decompiler.Shared/CodeMappings.cs | 323 + dnSpy/dnSpy.Decompiler.Shared/Extensions.cs | 238 + .../GenericArgumentResolver.cs | 240 + dnSpy/dnSpy.Decompiler.Shared/IILVariable.cs | 28 + .../IInstructionBytesReader.cs | 27 + dnSpy/dnSpy.Decompiler.Shared/ILRange.cs | 132 + dnSpy/dnSpy.Decompiler.Shared/ITextOutput.cs | 70 + .../IdentifierEscaper.cs | 117 + .../InstructionReference.cs | 48 + .../dnSpy.Decompiler.Shared/MemberComparer.cs | 72 + .../PlainTextOutput.cs | 132 + .../Properties/AssemblyInfo.cs | 14 + .../SimpleXmlParser.cs | 86 + dnSpy/dnSpy.Decompiler.Shared/TextPosition.cs | 88 + .../dnSpy.Decompiler.Shared/TextTokenKind.cs | 635 ++ .../dnSpy.Decompiler.Shared/TokenReference.cs | 51 + .../TypesHierarchyHelpers.cs | 400 + .../dnSpy.Decompiler.Shared.csproj | 79 + .../CSharp/SimpleCSharpPrinter.cs | 1248 +++ dnSpy/dnSpy.Languages/FilenameUtils.cs | 97 + dnSpy/dnSpy.Languages/IL/ILLanguageHelper.cs | 50 + .../IL/InstructionBytesReader.cs | 37 + dnSpy/dnSpy.Languages/IL/InstructionUtils.cs | 227 + .../IL/ModifiedInstructionBytesReader.cs | 65 + .../IL/OriginalInstructionBytesReader.cs | 49 + dnSpy/dnSpy.Languages/Language.cs | 300 + .../MSBuild/AppConfigProjectFile.cs | 49 + .../MSBuild/ApplicationIcon.cs | 144 + .../MSBuild/ApplicationManifest.cs | 88 + .../MSBuild/AssemblyInfoProjectFile.cs | 60 + .../MSBuild/BamlResourceProjectFile.cs | 180 + dnSpy/dnSpy.Languages/MSBuild/BuildAction.cs | 35 + .../MSBuild/DecompileContext.cs | 32 + .../MSBuild/DefaultNamespaceFinder.cs | 135 + dnSpy/dnSpy.Languages/MSBuild/DotNetUtils.cs | 87 + dnSpy/dnSpy.Languages/MSBuild/FileUtils.cs | 58 + .../MSBuild/FilenameCreator.cs | 163 + dnSpy/dnSpy.Languages/MSBuild/IJob.cs | 29 + .../MSBuild/IMSBuildProgressListener.cs | 47 + .../MSBuild/IMSBuildProjectWriterLogger.cs | 31 + .../MSBuild/MSBuildProjectCreator.cs | 159 + .../MSBuild/NoMSBuildProjectWriterLogger.cs | 27 + dnSpy/dnSpy.Languages/MSBuild/Project.cs | 580 ++ .../MSBuild/ProjectCreatorOptions.cs | 79 + dnSpy/dnSpy.Languages/MSBuild/ProjectFile.cs | 35 + .../MSBuild/ProjectModuleOptions.cs | 93 + .../dnSpy.Languages/MSBuild/ProjectVersion.cs | 30 + .../dnSpy.Languages/MSBuild/ProjectWriter.cs | 410 + .../MSBuild/RawEmbeddedResourceProjectFile.cs | 53 + .../MSBuild/ResXProjectFile.cs | 116 + .../MSBuild/ResourceNameCreator.cs | 291 + .../MSBuild/ResourceProjectFile.cs | 52 + .../MSBuild/SatelliteAssemblyFinder.cs | 123 + .../MSBuild/SettingsProjectFile.cs | 289 + .../MSBuild/SettingsTypeProjectFile.cs | 167 + .../dnSpy.Languages/MSBuild/SolutionWriter.cs | 151 + .../MSBuild/SplashScreenProjectFile.cs | 52 + .../MSBuild/TypeProjectFile.cs | 68 + .../MSBuild/WinFormsProjectFile.cs | 157 + .../MSBuild/XamlTypeProjectFile.cs | 134 + .../Properties/AssemblyInfo.cs | 14 + .../Languages.Resources.Designer.cs | 405 + .../Properties/Languages.Resources.resx | 234 + .../Properties/Languages.Resources.ru.resx | 234 + .../Properties/Languages.Resources.zh-CN.resx | 234 + .../Settings/DecompilerOption.cs | 52 + dnSpy/dnSpy.Languages/TargetFrameworkInfo.cs | 414 + dnSpy/dnSpy.Languages/TargetFrameworkUtils.cs | 73 + dnSpy/dnSpy.Languages/dnSpy.Languages.csproj | 134 + .../ClassificationTypeConverter.cs | 385 + .../Properties/AssemblyInfo.cs | 14 + .../dnSpy.Roslyn.Shared.csproj | 60 + dnSpy/dnSpy.Roslyn.Shared/project.json | 12 + dnSpy/dnSpy.Shared/App/MsgBox.cs | 37 + .../AvalonEditSearchPanelLocalization.cs | 53 + .../AvalonEdit/ExtensionMethods.cs | 78 + dnSpy/dnSpy.Shared/Controls/FastTextBlock.cs | 267 + .../dnSpy.Shared/Controls/FastTreeNodeView.cs | 202 + dnSpy/dnSpy.Shared/Controls/FontUtils.cs | 135 + dnSpy/dnSpy.Shared/Controls/MetroWindow.cs | 689 ++ dnSpy/dnSpy.Shared/Controls/SysMenuButton.cs | 39 + dnSpy/dnSpy.Shared/Controls/TabButton.cs | 106 + dnSpy/dnSpy.Shared/Controls/WinSysButton.cs | 131 + dnSpy/dnSpy.Shared/Controls/WindowBase.cs | 42 + .../Decompiler/AvalonEditTextOutput.cs | 265 + .../Decompiler/ISmartTextOutput.cs | 51 + .../OutputLengthExceededException.cs | 36 + dnSpy/dnSpy.Shared/Files/AnnotationsImpl.cs | 48 + dnSpy/dnSpy.Shared/Files/DnSpyFile.cs | 320 + dnSpy/dnSpy.Shared/Files/GacInfo.cs | 300 + .../Files/TreeView/FileTreeNodeData.cs | 220 + .../Files/TreeView/NodePrinter.cs | 185 + .../Files/TreeView/Resources/Deserializer.cs | 103 + .../Files/TreeView/Resources/GuessFileType.cs | 152 + .../TreeView/Resources/ImageResourceUtils.cs | 50 + .../TreeView/Resources/ResourceElementNode.cs | 322 + .../Files/TreeView/Resources/ResourceNode.cs | 186 + .../Files/TreeView/Resources/ResourceUtils.cs | 136 + .../Files/TreeView/Resources/SaveResources.cs | 189 + .../TreeView/Resources/SerializationUtils.cs | 105 + .../SerializedImageListStreamerUtils.cs | 122 + .../Resources/SerializedImageUtils.cs | 100 + .../SerializedResourceElementNode.cs | 128 + dnSpy/dnSpy.Shared/Hex/DnHexBox.cs | 260 + dnSpy/dnSpy.Shared/Hex/GoToOffsetDlg.xaml | 58 + dnSpy/dnSpy.Shared/Hex/GoToOffsetDlg.xaml.cs | 35 + dnSpy/dnSpy.Shared/Hex/GoToOffsetVM.cs | 40 + dnSpy/dnSpy.Shared/Hex/HexBoxCommands.cs | 702 ++ dnSpy/dnSpy.Shared/Hex/HexBoxThemeHelper.cs | 89 + .../Hex/HexEditorAppSettingsTab.cs | 148 + dnSpy/dnSpy.Shared/Hex/HexEditorSettings.cs | 198 + dnSpy/dnSpy.Shared/Hex/LocalHexSettings.cs | 69 + dnSpy/dnSpy.Shared/Hex/LocalSettingsDlg.xaml | 95 + .../dnSpy.Shared/Hex/LocalSettingsDlg.xaml.cs | 28 + dnSpy/dnSpy.Shared/Hex/LocalSettingsVM.cs | 225 + dnSpy/dnSpy.Shared/Hex/MDUtils.cs | 51 + dnSpy/dnSpy.Shared/Hex/SelectDlg.xaml | 62 + dnSpy/dnSpy.Shared/Hex/SelectDlg.xaml.cs | 36 + dnSpy/dnSpy.Shared/Hex/SelectVM.cs | 49 + dnSpy/dnSpy.Shared/HexEditor/AsciiEncoding.cs | 30 + .../HexEditor/ByteArrayHexStream.cs | 209 + .../dnSpy.Shared/HexEditor/CachedHexStream.cs | 236 + .../dnSpy.Shared/HexEditor/ClipboardUtils.cs | 89 + dnSpy/dnSpy.Shared/HexEditor/DataFormatter.cs | 255 + dnSpy/dnSpy.Shared/HexEditor/HexBox.cs | 2236 ++++++ .../dnSpy.Shared/HexEditor/HexBoxPosition.cs | 88 + .../HexEditor/HexBoxPositionKind.cs | 25 + dnSpy/dnSpy.Shared/HexEditor/HexBoxState.cs | 79 + .../HexEditor/HexBoxWriteEventArgs.cs | 45 + dnSpy/dnSpy.Shared/HexEditor/HexCaret.cs | 205 + dnSpy/dnSpy.Shared/HexEditor/HexDocument.cs | 116 + .../HexEditor/HexDocumentModifiedEventArgs.cs | 32 + dnSpy/dnSpy.Shared/HexEditor/HexLine.cs | 89 + dnSpy/dnSpy.Shared/HexEditor/HexLineLayer.cs | 80 + dnSpy/dnSpy.Shared/HexEditor/HexLinePart.cs | 34 + .../HexEditor/HexLineTextSource.cs | 62 + dnSpy/dnSpy.Shared/HexEditor/HexPositionUI.cs | 77 + dnSpy/dnSpy.Shared/HexEditor/HexSelection.cs | 69 + .../HexEditor/HexTextParagraphProperties.cs | 66 + .../HexEditor/HexTextRunProperties.cs | 149 + dnSpy/dnSpy.Shared/HexEditor/HexWriteType.cs | 27 + .../HexEditor/HtmlClipboardFormatWriter.cs | 102 + dnSpy/dnSpy.Shared/HexEditor/IHexLayer.cs | 24 + dnSpy/dnSpy.Shared/HexEditor/IHexStream.cs | 142 + .../HexEditor/ISimpleHexStream.cs | 65 + dnSpy/dnSpy.Shared/HexEditor/NumberUtils.cs | 44 + .../dnSpy.Shared/HexEditor/SelectionLayer.cs | 99 + .../Highlighting/ISyntaxHighlightOutput.cs | 161 + dnSpy/dnSpy.Shared/Highlighting/NameUtils.cs | 48 + .../Highlighting/NoSyntaxHighlightOutput.cs | 48 + .../Highlighting/SyntaxHighlighter.cs | 293 + .../Highlighting/TextTokenInfo.cs | 194 + .../Highlighting/UISyntaxHighlighter.cs | 107 + dnSpy/dnSpy.Shared/Images/Copy.png | Bin 0 -> 194 bytes dnSpy/dnSpy.Shared/Images/Fill.png | Bin 0 -> 376 bytes .../Images/ImageManagerExtensionMethods.cs | 37 + dnSpy/dnSpy.Shared/Images/Paste.png | Bin 0 -> 265 bytes dnSpy/dnSpy.Shared/Images/dnSpy.ico | Bin 0 -> 67646 bytes .../Languages/StringBuilderExtensions.cs | 40 + .../Languages/XmlDoc/XmlDocKeyProvider.cs | 301 + .../Languages/XmlDoc/XmlDocLoader.cs | 159 + .../Languages/XmlDoc/XmlDocRenderer.cs | 183 + .../XmlDoc/XmlDocumentationProvider.cs | 439 ++ .../Converters/BooleanToThicknessConverter.cs | 40 + .../MVVM/Converters/FontSizeConverter.cs | 39 + .../MVVM/Converters/NegateBooleanConverter.cs | 34 + dnSpy/dnSpy.Shared/MVVM/DataFieldVM.cs | 1185 +++ .../MVVM/Dialogs/ProgressDlg.xaml | 57 + .../MVVM/Dialogs/ProgressDlg.xaml.cs | 68 + dnSpy/dnSpy.Shared/MVVM/Dialogs/ProgressVM.cs | 232 + dnSpy/dnSpy.Shared/MVVM/EnumVM.cs | 109 + .../MVVM/IInitializeDataTemplate.cs | 26 + dnSpy/dnSpy.Shared/MVVM/InitDataTemplateAP.cs | 58 + dnSpy/dnSpy.Shared/MVVM/IsDraggableAP.cs | 35 + dnSpy/dnSpy.Shared/MVVM/ListVM.cs | 150 + dnSpy/dnSpy.Shared/MVVM/NumberVMUtils.cs | 764 ++ dnSpy/dnSpy.Shared/MVVM/PickDirectory.cs | 44 + dnSpy/dnSpy.Shared/MVVM/PickFilename.cs | 66 + dnSpy/dnSpy.Shared/MVVM/PickSaveFilename.cs | 58 + dnSpy/dnSpy.Shared/MVVM/RelayCommand.cs | 46 + dnSpy/dnSpy.Shared/MVVM/UIUtils.cs | 135 + dnSpy/dnSpy.Shared/MVVM/ViewModelBase.cs | 61 + dnSpy/dnSpy.Shared/Menus/MenuItemBase.cs | 126 + dnSpy/dnSpy.Shared/Menus/MenuItemCommand.cs | 64 + dnSpy/dnSpy.Shared/Properties/AssemblyInfo.cs | 14 + .../dnSpy.Shared.Resources.Designer.cs | 1416 ++++ .../Properties/dnSpy.Shared.Resources.resx | 574 ++ .../Properties/dnSpy.Shared.Resources.ru.resx | 574 ++ .../dnSpy.Shared.Resources.zh-CN.resx | 572 ++ .../dnSpy.Shared/Resources/ResourceHelper.cs | 77 + dnSpy/dnSpy.Shared/Scripting/UIUtils.cs | 126 + .../Search/ChainFileTreeNodeFilter.cs | 138 + dnSpy/dnSpy.Shared/Search/DelayedAction.cs | 51 + .../Search/EntryPointFileTreeNodeFilter.cs | 74 + .../Search/FileTreeNodeFilterBase.cs | 132 + .../Search/FilterNothingFileTreeNodeFilter.cs | 24 + .../Search/FlagsFileTreeNodeFilter.cs | 362 + dnSpy/dnSpy.Shared/Search/NamespaceRef.cs | 32 + .../Search/NamespaceSearchResult.cs | 28 + .../Search/SameAssemblyFileTreeNodeFilter.cs | 46 + .../Search/SameModuleFileTreeNodeFilter.cs | 44 + dnSpy/dnSpy.Shared/Search/SearchComparers.cs | 317 + .../ShowNothingFileTreeNodeFilterBase.cs | 132 + .../Search/VisibleMembersFlags.cs | 65 + .../Settings/Dialog/SimpleAppOption.cs | 129 + dnSpy/dnSpy.Shared/Themes/ExtensionMethods.cs | 29 + .../Themes/wpf.styles.templates.xaml | 656 ++ .../ToolBars/ToolBarButtonBase.cs | 46 + .../ToolBars/ToolBarButtonCommand.cs | 43 + .../ToolBars/ToolBarObjectBase.cs | 31 + .../dnSpy.Shared/TreeView/AsyncNodeCreator.cs | 146 + dnSpy/dnSpy.Shared/TreeView/TreeNodeData.cs | 105 + dnSpy/dnSpy.Shared/dnSpy.Shared.csproj | 260 + dnSpy/dnSpy/App.config | 58 + dnSpy/dnSpy/Controls/IStackedContentChild.cs | 30 + dnSpy/dnSpy/Controls/StackedContent.cs | 363 + dnSpy/dnSpy/Controls/StackedContentState.cs | 62 + dnSpy/dnSpy/Controls/WpfCommandManager.cs | 58 + dnSpy/dnSpy/Controls/WpfCommands.cs | 143 + dnSpy/dnSpy/Controls/WpfFocusManager.cs | 50 + dnSpy/dnSpy/Converters/ImageConverter.cs | 51 + dnSpy/dnSpy/Culture/Commands.cs | 126 + dnSpy/dnSpy/Culture/CultureManager.cs | 160 + dnSpy/dnSpy/Culture/CultureSettings.cs | 72 + dnSpy/dnSpy/Culture/LanguageInfo.cs | 88 + dnSpy/dnSpy/Decompiler/CodeMappings.cs | 136 + .../dnSpy/Decompiler/DecompilerSettingsTab.cs | 106 + dnSpy/dnSpy/Events/WeakEventList.cs | 133 + .../DOTNET Framework v3.5 Client.FileList.xml | 94 + .../DOTNET Framework v4.0 Client.FileList.xml | 93 + dnSpy/dnSpy/Files/AssemblyResolver.cs | 242 + dnSpy/dnSpy/Files/DefaultDnSpyFileCreator.cs | 73 + dnSpy/dnSpy/Files/DefaultDnSpyFileLoader.cs | 46 + dnSpy/dnSpy/Files/FileLoader.cs | 97 + dnSpy/dnSpy/Files/FileManager.cs | 366 + .../FileManagerAppSettingsModifiedListener.cs | 47 + dnSpy/dnSpy/Files/FileManagerCreator.cs | 40 + dnSpy/dnSpy/Files/FileManagerOptionCreator.cs | 52 + dnSpy/dnSpy/Files/FileManagerSettings.cs | 96 + dnSpy/dnSpy/Files/IDnSpyFileLoader.cs | 36 + dnSpy/dnSpy/Files/MethodAnnotations.cs | 110 + .../Files/Tabs/AppCommandLineArgsHandler.cs | 116 + dnSpy/dnSpy/Files/Tabs/AsyncShowResult.cs | 40 + dnSpy/dnSpy/Files/Tabs/Commands.cs | 302 + dnSpy/dnSpy/Files/Tabs/CopyTokenCommand.cs | 122 + dnSpy/dnSpy/Files/Tabs/DecompilationCache.cs | 277 + .../dnSpy/Files/Tabs/DefaultDecompileNode.cs | 32 + dnSpy/dnSpy/Files/Tabs/DefaultFileList.cs | 452 ++ .../Tabs/Dialogs/ExportToProjectDlg.xaml | 127 + .../Tabs/Dialogs/ExportToProjectDlg.xaml.cs | 37 + .../Tabs/Dialogs/ExportToProjectSettings.cs | 73 + .../Files/Tabs/Dialogs/ExportToProjectVM.cs | 385 + .../Tabs/Dialogs/FileListColumnConverter.cs | 49 + .../Files/Tabs/Dialogs/FileListPrinter.cs | 39 + dnSpy/dnSpy/Files/Tabs/Dialogs/FileListVM.cs | 72 + .../Tabs/Dialogs/GACFileColumnConverter.cs | 49 + .../dnSpy/Files/Tabs/Dialogs/GACFileFinder.cs | 78 + .../Files/Tabs/Dialogs/GACFilePrinter.cs | 40 + dnSpy/dnSpy/Files/Tabs/Dialogs/GACFileVM.cs | 144 + .../Files/Tabs/Dialogs/OpenFileListDlg.xaml | 101 + .../Tabs/Dialogs/OpenFileListDlg.xaml.cs | 73 + .../Files/Tabs/Dialogs/OpenFileListVM.cs | 245 + .../Files/Tabs/Dialogs/OpenFromGACDlg.xaml | 120 + .../Files/Tabs/Dialogs/OpenFromGACDlg.xaml.cs | 54 + .../dnSpy/Files/Tabs/Dialogs/OpenFromGACVM.cs | 209 + .../Files/Tabs/Dialogs/TabColumnConverter.cs | 51 + dnSpy/dnSpy/Files/Tabs/Dialogs/TabPrinter.cs | 44 + dnSpy/dnSpy/Files/Tabs/Dialogs/TabVM.cs | 71 + dnSpy/dnSpy/Files/Tabs/Dialogs/TabsDlg.xaml | 91 + .../dnSpy/Files/Tabs/Dialogs/TabsDlg.xaml.cs | 59 + dnSpy/dnSpy/Files/Tabs/Dialogs/TabsVM.cs | 140 + .../Files/Tabs/Dialogs/TabsVMSettings.cs | 72 + .../Files/Tabs/DnSpyFileInfoSerializer.cs | 43 + dnSpy/dnSpy/Files/Tabs/EntryPointCommands.cs | 159 + dnSpy/dnSpy/Files/Tabs/FileList.cs | 101 + dnSpy/dnSpy/Files/Tabs/FileListLoader.cs | 228 + dnSpy/dnSpy/Files/Tabs/FileListManager.cs | 119 + .../Tabs/FileTabContentFactoryContext.cs | 34 + .../Tabs/FileTabContentFactoryManager.cs | 77 + dnSpy/dnSpy/Files/Tabs/FileTabManager.cs | 690 ++ .../dnSpy/Files/Tabs/FileTabManagerLoader.cs | 85 + .../Files/Tabs/FileTabManagerSettings.cs | 92 + dnSpy/dnSpy/Files/Tabs/FileTabSerializer.cs | 76 + .../Files/Tabs/FileTabUIContextLocator.cs | 101 + .../Tabs/FileTabUIContextLocatorCreator.cs | 40 + .../Files/Tabs/FileTreeNodeDecompiler.cs | 73 + dnSpy/dnSpy/Files/Tabs/GoToTokenCommand.cs | 163 + dnSpy/dnSpy/Files/Tabs/IDecompilationCache.cs | 61 + .../Tabs/IFileTabUIContextLocatorCreator.cs | 33 + dnSpy/dnSpy/Files/Tabs/MiscOptions.cs | 49 + dnSpy/dnSpy/Files/Tabs/NavigationCommands.cs | 85 + dnSpy/dnSpy/Files/Tabs/NodeDecompiler.cs | 341 + .../NodeReferenceFileTabContentCreator.cs | 85 + dnSpy/dnSpy/Files/Tabs/NodeTabSaver.cs | 152 + dnSpy/dnSpy/Files/Tabs/NullObjects.cs | 122 + dnSpy/dnSpy/Files/Tabs/RedecompileTabs.cs | 56 + .../Files/Tabs/RefreshResourcesCommand.cs | 99 + dnSpy/dnSpy/Files/Tabs/ResourceCommands.cs | 254 + dnSpy/dnSpy/Files/Tabs/SaveCommands.cs | 356 + dnSpy/dnSpy/Files/Tabs/SaveManager.cs | 65 + dnSpy/dnSpy/Files/Tabs/SearchMsdnCommand.cs | 305 + dnSpy/dnSpy/Files/Tabs/SerializedTabs.cs | 428 + .../Files/Tabs/Settings/DisplaySettingsTab.cs | 300 + dnSpy/dnSpy/Files/Tabs/TabCommands.cs | 845 ++ dnSpy/dnSpy/Files/Tabs/TabContentImpl.cs | 454 ++ dnSpy/dnSpy/Files/Tabs/TabHistory.cs | 111 + dnSpy/dnSpy/Files/Tabs/TextEditor/Commands.cs | 202 + .../TextEditor/DecompileFileTabContent.cs | 277 + .../Tabs/TextEditor/DecompileNodeContext.cs | 71 + .../Tabs/TextEditor/IconBarCommandManager.cs | 108 + .../Files/Tabs/TextEditor/IconBarMargin.cs | 118 + .../TextEditor/ReferenceElementGenerator.cs | 125 + .../Tabs/TextEditor/TextEditorControl.xaml | 32 + .../Tabs/TextEditor/TextEditorControl.xaml.cs | 808 ++ .../Tabs/TextEditor/TextEditorUIContext.cs | 329 + .../TextEditor/TextEditorUIContextCreator.cs | 97 + .../TextEditorUIContextManagerImpl.cs | 110 + .../Tabs/TextEditor/TextLineObjectManager.cs | 68 + .../Tabs/TextEditor/TextMarkerService.cs | 383 + .../TextEditor/ToolTips/CodeToolTipCreator.cs | 122 + .../TextEditor/ToolTips/CodeToolTipManager.cs | 64 + .../ToolTips/CodeToolTipSettings.cs | 72 + .../TextEditor/ToolTips/CodeToolTipWriter.cs | 142 + .../DnlibReferenceToolTipContentCreator.cs | 204 + .../ToolTips/ToolTipContentCreatorContext.cs | 46 + .../Tabs/TextEditor/ToolTips/ToolTipHelper.cs | 82 + .../Tabs/TextEditor/UIElementGenerator.cs | 69 + .../Files/Tabs/TextEditor/WaitAdorner.xaml | 20 + .../Files/Tabs/TextEditor/WaitAdorner.xaml.cs | 39 + .../TreeNodeReferenceFileTabContentCreator.cs | 160 + .../dnSpy/Files/TreeView/AssemblyFileNode.cs | 93 + .../Files/TreeView/AssemblyReferenceNode.cs | 95 + .../Files/TreeView/BaseTypeFolderNode.cs | 86 + dnSpy/dnSpy/Files/TreeView/BaseTypeNode.cs | 114 + .../TreeView/DefaultDnSpyFileNodeCreator.cs | 42 + dnSpy/dnSpy/Files/TreeView/DerivedTypeNode.cs | 105 + .../Files/TreeView/DerivedTypesFinder.cs | 91 + .../Files/TreeView/DerivedTypesFolderNode.cs | 84 + dnSpy/dnSpy/Files/TreeView/DnSpyFileNode.cs | 46 + dnSpy/dnSpy/Files/TreeView/EventNode.cs | 91 + dnSpy/dnSpy/Files/TreeView/FieldNode.cs | 75 + .../Files/TreeView/FileTreeNodeDataContext.cs | 55 + .../Files/TreeView/FileTreeNodeGroups.cs | 489 ++ dnSpy/dnSpy/Files/TreeView/FileTreeView.cs | 917 +++ ...FileTreeViewAppSettingsModifiedListener.cs | 40 + .../Files/TreeView/FileTreeViewCreator.cs | 71 + .../Files/TreeView/FileTreeViewSettings.cs | 217 + dnSpy/dnSpy/Files/TreeView/MessageNode.cs | 71 + dnSpy/dnSpy/Files/TreeView/MethodNode.cs | 75 + dnSpy/dnSpy/Files/TreeView/ModuleFileNode.cs | 120 + .../Files/TreeView/ModuleReferenceNode.cs | 70 + dnSpy/dnSpy/Files/TreeView/NamespaceNode.cs | 93 + dnSpy/dnSpy/Files/TreeView/PEFileNode.cs | 78 + dnSpy/dnSpy/Files/TreeView/PropertyNode.cs | 89 + .../Files/TreeView/ReferencesFolderNode.cs | 87 + .../Resources/BuiltInResourceElementNode.cs | 91 + .../TreeView/Resources/ImageResourceNode.cs | 236 + .../Resources/ResourceElementSetNode.cs | 120 + .../TreeView/Resources/ResourceNodeFactory.cs | 69 + ...zedImageListStreamerResourceElementNode.cs | 119 + .../SerializedImageResourceElementNode.cs | 135 + .../TreeView/Resources/UnknownResourceNode.cs | 68 + .../UnknownSerializedResourceElementNode.cs | 51 + .../Files/TreeView/ResourcesFolderNode.cs | 83 + dnSpy/dnSpy/Files/TreeView/RootNode.cs | 95 + dnSpy/dnSpy/Files/TreeView/TypeNode.cs | 120 + dnSpy/dnSpy/Files/TreeView/UnknownFileNode.cs | 55 + dnSpy/dnSpy/Images/Assembly.png | Bin 0 -> 153 bytes dnSpy/dnSpy/Images/AssemblyExe.png | Bin 0 -> 240 bytes dnSpy/dnSpy/Images/AssemblyModule.png | Bin 0 -> 133 bytes dnSpy/dnSpy/Images/AssemblyReference.png | Bin 0 -> 141 bytes dnSpy/dnSpy/Images/AssemblyWarning.png | Bin 0 -> 249 bytes dnSpy/dnSpy/Images/Backward.png | Bin 0 -> 243 bytes dnSpy/dnSpy/Images/BaseTypeClosed.png | Bin 0 -> 196 bytes dnSpy/dnSpy/Images/BaseTypeOpened.png | Bin 0 -> 345 bytes dnSpy/dnSpy/Images/Binary.png | Bin 0 -> 149 bytes dnSpy/dnSpy/Images/CSharpFile.png | Bin 0 -> 238 bytes dnSpy/dnSpy/Images/Class.png | Bin 0 -> 212 bytes dnSpy/dnSpy/Images/ClassInternal.png | Bin 0 -> 280 bytes dnSpy/dnSpy/Images/ClassPrivate.png | Bin 0 -> 379 bytes dnSpy/dnSpy/Images/ClassProtected.png | Bin 0 -> 422 bytes dnSpy/dnSpy/Images/ClassProtectedInternal.png | Bin 0 -> 370 bytes dnSpy/dnSpy/Images/ClearWindowContent.png | Bin 0 -> 320 bytes dnSpy/dnSpy/Images/Close.png | Bin 0 -> 251 bytes dnSpy/dnSpy/Images/CloseAll.png | Bin 0 -> 241 bytes dnSpy/dnSpy/Images/CloseDocuments.png | Bin 0 -> 365 bytes dnSpy/dnSpy/Images/Constructor.png | Bin 0 -> 354 bytes .../Images/ConstructorCompilerControlled.png | Bin 0 -> 390 bytes dnSpy/dnSpy/Images/ConstructorInternal.png | Bin 0 -> 437 bytes dnSpy/dnSpy/Images/ConstructorPrivate.png | Bin 0 -> 379 bytes dnSpy/dnSpy/Images/ConstructorProtected.png | Bin 0 -> 447 bytes .../Images/ConstructorProtectedInternal.png | Bin 0 -> 377 bytes dnSpy/dnSpy/Images/Copy.png | Bin 0 -> 194 bytes dnSpy/dnSpy/Images/Delegate.png | Bin 0 -> 242 bytes dnSpy/dnSpy/Images/DelegateInternal.png | Bin 0 -> 371 bytes dnSpy/dnSpy/Images/DelegatePrivate.png | Bin 0 -> 351 bytes dnSpy/dnSpy/Images/DelegateProtected.png | Bin 0 -> 367 bytes .../Images/DelegateProtectedInternal.png | Bin 0 -> 281 bytes dnSpy/dnSpy/Images/DerivedTypesClosed.png | Bin 0 -> 231 bytes dnSpy/dnSpy/Images/DerivedTypesOpened.png | Bin 0 -> 367 bytes dnSpy/dnSpy/Images/DotNetImageManager.cs | 601 ++ dnSpy/dnSpy/Images/EntryPoint.png | Bin 0 -> 221 bytes dnSpy/dnSpy/Images/Enum.png | Bin 0 -> 190 bytes dnSpy/dnSpy/Images/EnumInternal.png | Bin 0 -> 265 bytes dnSpy/dnSpy/Images/EnumPrivate.png | Bin 0 -> 216 bytes dnSpy/dnSpy/Images/EnumProtected.png | Bin 0 -> 271 bytes dnSpy/dnSpy/Images/EnumProtectedInternal.png | Bin 0 -> 212 bytes dnSpy/dnSpy/Images/EnumValue.png | Bin 0 -> 259 bytes .../Images/EnumValueCompilerControlled.png | Bin 0 -> 209 bytes dnSpy/dnSpy/Images/EnumValueInternal.png | Bin 0 -> 258 bytes dnSpy/dnSpy/Images/EnumValuePrivate.png | Bin 0 -> 204 bytes dnSpy/dnSpy/Images/EnumValueProtected.png | Bin 0 -> 263 bytes .../Images/EnumValueProtectedInternal.png | Bin 0 -> 201 bytes dnSpy/dnSpy/Images/Event.png | Bin 0 -> 210 bytes .../dnSpy/Images/EventCompilerControlled.png | Bin 0 -> 247 bytes dnSpy/dnSpy/Images/EventInternal.png | Bin 0 -> 281 bytes dnSpy/dnSpy/Images/EventPrivate.png | Bin 0 -> 242 bytes dnSpy/dnSpy/Images/EventProtected.png | Bin 0 -> 291 bytes dnSpy/dnSpy/Images/EventProtectedInternal.png | Bin 0 -> 240 bytes dnSpy/dnSpy/Images/Exception.png | Bin 0 -> 138 bytes dnSpy/dnSpy/Images/ExceptionInternal.png | Bin 0 -> 210 bytes dnSpy/dnSpy/Images/ExceptionPrivate.png | Bin 0 -> 157 bytes dnSpy/dnSpy/Images/ExceptionProtected.png | Bin 0 -> 222 bytes .../Images/ExceptionProtectedInternal.png | Bin 0 -> 155 bytes dnSpy/dnSpy/Images/ExtensionMethod.png | Bin 0 -> 354 bytes .../ExtensionMethodCompilerControlled.png | Bin 0 -> 390 bytes .../dnSpy/Images/ExtensionMethodInternal.png | Bin 0 -> 441 bytes dnSpy/dnSpy/Images/ExtensionMethodPrivate.png | Bin 0 -> 379 bytes .../dnSpy/Images/ExtensionMethodProtected.png | Bin 0 -> 449 bytes .../ExtensionMethodProtectedInternal.png | Bin 0 -> 377 bytes dnSpy/dnSpy/Images/Field.png | Bin 0 -> 216 bytes .../dnSpy/Images/FieldCompilerControlled.png | Bin 0 -> 253 bytes dnSpy/dnSpy/Images/FieldInternal.png | Bin 0 -> 292 bytes dnSpy/dnSpy/Images/FieldPrivate.png | Bin 0 -> 245 bytes dnSpy/dnSpy/Images/FieldProtected.png | Bin 0 -> 300 bytes dnSpy/dnSpy/Images/FieldProtectedInternal.png | Bin 0 -> 246 bytes dnSpy/dnSpy/Images/FieldReadOnly.png | Bin 0 -> 285 bytes .../FieldReadOnlyCompilerControlled.png | Bin 0 -> 340 bytes dnSpy/dnSpy/Images/FieldReadOnlyInternal.png | Bin 0 -> 376 bytes dnSpy/dnSpy/Images/FieldReadOnlyPrivate.png | Bin 0 -> 330 bytes dnSpy/dnSpy/Images/FieldReadOnlyProtected.png | Bin 0 -> 385 bytes .../Images/FieldReadOnlyProtectedInternal.png | Bin 0 -> 324 bytes dnSpy/dnSpy/Images/Find.png | Bin 0 -> 522 bytes dnSpy/dnSpy/Images/FolderClosed.png | Bin 0 -> 196 bytes dnSpy/dnSpy/Images/FolderOpened.png | Bin 0 -> 345 bytes dnSpy/dnSpy/Images/Forward.png | Bin 0 -> 252 bytes dnSpy/dnSpy/Images/FullScreen.png | Bin 0 -> 197 bytes dnSpy/dnSpy/Images/Generic.png | Bin 0 -> 235 bytes dnSpy/dnSpy/Images/GenericInternal.png | Bin 0 -> 275 bytes dnSpy/dnSpy/Images/GenericParameter.png | Bin 0 -> 222 bytes dnSpy/dnSpy/Images/GenericPrivate.png | Bin 0 -> 238 bytes dnSpy/dnSpy/Images/GenericProtected.png | Bin 0 -> 288 bytes .../dnSpy/Images/GenericProtectedInternal.png | Bin 0 -> 238 bytes dnSpy/dnSpy/Images/HorizontalTabGroup.png | Bin 0 -> 131 bytes dnSpy/dnSpy/Images/ImageFile.png | Bin 0 -> 310 bytes dnSpy/dnSpy/Images/ImageManager.cs | 98 + dnSpy/dnSpy/Images/Interface.png | Bin 0 -> 222 bytes dnSpy/dnSpy/Images/InterfaceInternal.png | Bin 0 -> 293 bytes dnSpy/dnSpy/Images/InterfacePrivate.png | Bin 0 -> 250 bytes dnSpy/dnSpy/Images/InterfaceProtected.png | Bin 0 -> 307 bytes .../Images/InterfaceProtectedInternal.png | Bin 0 -> 249 bytes dnSpy/dnSpy/Images/Library.png | Bin 0 -> 151 bytes dnSpy/dnSpy/Images/Literal.png | Bin 0 -> 165 bytes .../Images/LiteralCompilerControlled.png | Bin 0 -> 392 bytes dnSpy/dnSpy/Images/LiteralInternal.png | Bin 0 -> 240 bytes dnSpy/dnSpy/Images/LiteralPrivate.png | Bin 0 -> 259 bytes dnSpy/dnSpy/Images/LiteralProtected.png | Bin 0 -> 310 bytes .../dnSpy/Images/LiteralProtectedInternal.png | Bin 0 -> 183 bytes dnSpy/dnSpy/Images/Local.png | Bin 0 -> 321 bytes dnSpy/dnSpy/Images/MarkUpTag.png | Bin 0 -> 278 bytes dnSpy/dnSpy/Images/Method.png | Bin 0 -> 276 bytes .../dnSpy/Images/MethodCompilerControlled.png | Bin 0 -> 312 bytes dnSpy/dnSpy/Images/MethodInternal.png | Bin 0 -> 350 bytes dnSpy/dnSpy/Images/MethodPrivate.png | Bin 0 -> 304 bytes dnSpy/dnSpy/Images/MethodProtected.png | Bin 0 -> 361 bytes .../dnSpy/Images/MethodProtectedInternal.png | Bin 0 -> 303 bytes dnSpy/dnSpy/Images/ModuleReference.png | Bin 0 -> 242 bytes dnSpy/dnSpy/Images/Namespace.png | Bin 0 -> 250 bytes dnSpy/dnSpy/Images/NewWindow.png | Bin 0 -> 217 bytes dnSpy/dnSpy/Images/OneLevelUp.png | Bin 0 -> 301 bytes dnSpy/dnSpy/Images/Open.png | Bin 0 -> 411 bytes dnSpy/dnSpy/Images/Operator.png | Bin 0 -> 149 bytes .../Images/OperatorCompilerControlled.png | Bin 0 -> 432 bytes dnSpy/dnSpy/Images/OperatorInternal.png | Bin 0 -> 226 bytes dnSpy/dnSpy/Images/OperatorPrivate.png | Bin 0 -> 171 bytes dnSpy/dnSpy/Images/OperatorProtected.png | Bin 0 -> 240 bytes .../Images/OperatorProtectedInternal.png | Bin 0 -> 175 bytes dnSpy/dnSpy/Images/Output.png | Bin 0 -> 297 bytes dnSpy/dnSpy/Images/PInvokeMethod.png | Bin 0 -> 342 bytes .../PInvokeMethodCompilerControlled.png | Bin 0 -> 372 bytes dnSpy/dnSpy/Images/PInvokeMethodInternal.png | Bin 0 -> 416 bytes dnSpy/dnSpy/Images/PInvokeMethodPrivate.png | Bin 0 -> 363 bytes dnSpy/dnSpy/Images/PInvokeMethodProtected.png | Bin 0 -> 429 bytes .../Images/PInvokeMethodProtectedInternal.png | Bin 0 -> 361 bytes dnSpy/dnSpy/Images/Parameter.png | Bin 0 -> 172 bytes dnSpy/dnSpy/Images/Property.png | Bin 0 -> 316 bytes .../Images/PropertyCompilerControlled.png | Bin 0 -> 500 bytes dnSpy/dnSpy/Images/PropertyInternal.png | Bin 0 -> 283 bytes dnSpy/dnSpy/Images/PropertyPrivate.png | Bin 0 -> 364 bytes dnSpy/dnSpy/Images/PropertyProtected.png | Bin 0 -> 298 bytes .../Images/PropertyProtectedInternal.png | Bin 0 -> 348 bytes dnSpy/dnSpy/Images/ReferenceFolder.png | Bin 0 -> 172 bytes dnSpy/dnSpy/Images/Resource.png | Bin 0 -> 183 bytes dnSpy/dnSpy/Images/ResourcesFile.png | Bin 0 -> 285 bytes dnSpy/dnSpy/Images/Save.png | Bin 0 -> 218 bytes dnSpy/dnSpy/Images/Search.png | Bin 0 -> 522 bytes dnSpy/dnSpy/Images/Settings.png | Bin 0 -> 274 bytes dnSpy/dnSpy/Images/Solution.png | Bin 0 -> 310 bytes dnSpy/dnSpy/Images/StaticClass.png | Bin 0 -> 210 bytes dnSpy/dnSpy/Images/StaticEvent.png | Bin 0 -> 285 bytes .../Images/StaticEventCompilerControlled.png | Bin 0 -> 330 bytes dnSpy/dnSpy/Images/StaticEventInternal.png | Bin 0 -> 367 bytes dnSpy/dnSpy/Images/StaticEventPrivate.png | Bin 0 -> 320 bytes dnSpy/dnSpy/Images/StaticEventProtected.png | Bin 0 -> 381 bytes .../Images/StaticEventProtectedInternal.png | Bin 0 -> 322 bytes dnSpy/dnSpy/Images/StaticMethod.png | Bin 0 -> 355 bytes .../Images/StaticMethodCompilerControlled.png | Bin 0 -> 391 bytes dnSpy/dnSpy/Images/StaticMethodInternal.png | Bin 0 -> 438 bytes dnSpy/dnSpy/Images/StaticMethodPrivate.png | Bin 0 -> 379 bytes dnSpy/dnSpy/Images/StaticMethodProtected.png | Bin 0 -> 448 bytes .../Images/StaticMethodProtectedInternal.png | Bin 0 -> 377 bytes dnSpy/dnSpy/Images/StaticProperty.png | Bin 0 -> 310 bytes .../StaticPropertyCompilerControlled.png | Bin 0 -> 428 bytes dnSpy/dnSpy/Images/StaticPropertyInternal.png | Bin 0 -> 391 bytes dnSpy/dnSpy/Images/StaticPropertyPrivate.png | Bin 0 -> 350 bytes .../dnSpy/Images/StaticPropertyProtected.png | Bin 0 -> 403 bytes .../StaticPropertyProtectedInternal.png | Bin 0 -> 343 bytes dnSpy/dnSpy/Images/Strings.png | Bin 0 -> 154 bytes dnSpy/dnSpy/Images/Struct.png | Bin 0 -> 136 bytes dnSpy/dnSpy/Images/StructInternal.png | Bin 0 -> 231 bytes dnSpy/dnSpy/Images/StructPrivate.png | Bin 0 -> 160 bytes dnSpy/dnSpy/Images/StructProtected.png | Bin 0 -> 225 bytes .../dnSpy/Images/StructProtectedInternal.png | Bin 0 -> 160 bytes dnSpy/dnSpy/Images/TextFile.png | Bin 0 -> 239 bytes dnSpy/dnSpy/Images/ThemedImageCreator.cs | 144 + dnSpy/dnSpy/Images/UserDefinedDataType.png | Bin 0 -> 255 bytes dnSpy/dnSpy/Images/VerticalTabGroup.png | Bin 0 -> 136 bytes dnSpy/dnSpy/Images/VirtualEvent.png | Bin 0 -> 285 bytes .../Images/VirtualEventCompilerControlled.png | Bin 0 -> 330 bytes dnSpy/dnSpy/Images/VirtualEventInternal.png | Bin 0 -> 367 bytes dnSpy/dnSpy/Images/VirtualEventPrivate.png | Bin 0 -> 320 bytes dnSpy/dnSpy/Images/VirtualEventProtected.png | Bin 0 -> 380 bytes .../Images/VirtualEventProtectedInternal.png | Bin 0 -> 322 bytes dnSpy/dnSpy/Images/VirtualMethod.png | Bin 0 -> 354 bytes .../VirtualMethodCompilerControlled.png | Bin 0 -> 390 bytes dnSpy/dnSpy/Images/VirtualMethodInternal.png | Bin 0 -> 439 bytes dnSpy/dnSpy/Images/VirtualMethodPrivate.png | Bin 0 -> 379 bytes dnSpy/dnSpy/Images/VirtualMethodProtected.png | Bin 0 -> 447 bytes .../Images/VirtualMethodProtectedInternal.png | Bin 0 -> 377 bytes dnSpy/dnSpy/Images/VirtualProperty.png | Bin 0 -> 306 bytes .../VirtualPropertyCompilerControlled.png | Bin 0 -> 420 bytes .../dnSpy/Images/VirtualPropertyInternal.png | Bin 0 -> 380 bytes dnSpy/dnSpy/Images/VirtualPropertyPrivate.png | Bin 0 -> 337 bytes .../dnSpy/Images/VirtualPropertyProtected.png | Bin 0 -> 393 bytes .../VirtualPropertyProtectedInternal.png | Bin 0 -> 332 bytes dnSpy/dnSpy/Images/VisualBasicFile.png | Bin 0 -> 311 bytes dnSpy/dnSpy/Images/WordWrap.png | Bin 0 -> 194 bytes dnSpy/dnSpy/Images/XamlFile.png | Bin 0 -> 256 bytes dnSpy/dnSpy/Images/XmlFile.png | Bin 0 -> 310 bytes dnSpy/dnSpy/Images/XsdFile.png | Bin 0 -> 297 bytes dnSpy/dnSpy/Images/XsltFile.png | Bin 0 -> 207 bytes dnSpy/dnSpy/Images/dnSpy-Big.png | Bin 0 -> 819 bytes dnSpy/dnSpy/Images/dnSpy.ico | Bin 0 -> 67646 bytes dnSpy/dnSpy/Images/tableviewnameonly.png | Bin 0 -> 142 bytes dnSpy/dnSpy/Images/toolstrippanelbottom.png | Bin 0 -> 135 bytes dnSpy/dnSpy/Images/toolstrippanelleft.png | Bin 0 -> 133 bytes dnSpy/dnSpy/Images/toolstrippanelright.png | Bin 0 -> 132 bytes dnSpy/dnSpy/Images/toolstrippaneltop.png | Bin 0 -> 137 bytes dnSpy/dnSpy/Languages/DummyLanguage.cs | 77 + dnSpy/dnSpy/Languages/LanguageManager.cs | 80 + .../Languages/LanguageManagerSettings.cs | 73 + .../MVVM/InitializeDataTemplateContextMenu.cs | 43 + dnSpy/dnSpy/MainApp/AboutCommands.cs | 111 + dnSpy/dnSpy/MainApp/AboutScreen.cs | 276 + dnSpy/dnSpy/MainApp/App.xaml | 13 + dnSpy/dnSpy/MainApp/App.xaml.cs | 406 + dnSpy/dnSpy/MainApp/AppCommandLineArgs.cs | 249 + .../MainApp/AppCommandLineArgsHandler.cs | 111 + dnSpy/dnSpy/MainApp/AppSettings.cs | 96 + dnSpy/dnSpy/MainApp/AppStatusBar.cs | 68 + dnSpy/dnSpy/MainApp/AppToolBar.cs | 47 + dnSpy/dnSpy/MainApp/AppWindow.cs | 277 + dnSpy/dnSpy/MainApp/AskDlg.xaml | 60 + dnSpy/dnSpy/MainApp/AskDlg.xaml.cs | 28 + dnSpy/dnSpy/MainApp/AskVM.cs | 79 + dnSpy/dnSpy/MainApp/DnSpyLoaderControl.xaml | 48 + .../dnSpy/MainApp/DnSpyLoaderControl.xaml.cs | 32 + dnSpy/dnSpy/MainApp/DnSpyLoaderManager.cs | 162 + .../MainApp/FileTreeViewWindowContent.cs | 133 + .../MainApp/MainToolWindowManagerCommands.cs | 470 ++ dnSpy/dnSpy/MainApp/MainWindow.xaml | 34 + dnSpy/dnSpy/MainApp/MainWindow.xaml.cs | 49 + dnSpy/dnSpy/MainApp/MainWindowControl.cs | 660 ++ dnSpy/dnSpy/MainApp/MessageBoxManager.cs | 166 + dnSpy/dnSpy/MainApp/MiscOptions.cs | 216 + dnSpy/dnSpy/MainApp/MsgBoxDlg.xaml | 58 + dnSpy/dnSpy/MainApp/MsgBoxDlg.xaml.cs | 54 + dnSpy/dnSpy/MainApp/MsgBoxVM.cs | 121 + dnSpy/dnSpy/MainApp/SavedWindowState.cs | 119 + dnSpy/dnSpy/MainApp/StartUpClass.cs | 64 + dnSpy/dnSpy/MainApp/ToolBarCommands.cs | 138 + dnSpy/dnSpy/MainApp/ViewCommands.cs | 81 + dnSpy/dnSpy/Menus/AppMenus.cs | 46 + dnSpy/dnSpy/Menus/ContextMenuCreator.cs | 86 + dnSpy/dnSpy/Menus/MenuItemContext.cs | 74 + dnSpy/dnSpy/Menus/MenuManager.cs | 466 ++ dnSpy/dnSpy/Output/CachedWriter.cs | 49 + dnSpy/dnSpy/Output/Commands.cs | 100 + dnSpy/dnSpy/Output/NotPresentOutputWriter.cs | 53 + dnSpy/dnSpy/Output/NullOutputTextPane.cs | 47 + dnSpy/dnSpy/Output/OutputBufferVM.cs | 127 + dnSpy/dnSpy/Output/OutputCommands.cs | 41 + dnSpy/dnSpy/Output/OutputContent.cs | 102 + dnSpy/dnSpy/Output/OutputControl.xaml | 86 + dnSpy/dnSpy/Output/OutputControl.xaml.cs | 28 + dnSpy/dnSpy/Output/OutputManager.cs | 240 + dnSpy/dnSpy/Output/OutputManagerSettings.cs | 117 + dnSpy/dnSpy/Output/OutputToolWindowContent.cs | 99 + dnSpy/dnSpy/Plugin/LoadedPlugin.cs | 30 + dnSpy/dnSpy/Plugin/PluginConfig.cs | 51 + dnSpy/dnSpy/Plugin/PluginConfigReader.cs | 70 + dnSpy/dnSpy/Plugin/PluginManager.cs | 99 + dnSpy/dnSpy/Properties/AssemblyInfo.Shared.cs | 36 + dnSpy/dnSpy/Properties/AssemblyInfo.cs | 33 + .../Properties/dnSpy.Resources.Designer.cs | 2648 +++++++ dnSpy/dnSpy/Properties/dnSpy.Resources.resx | 983 +++ .../dnSpy/Properties/dnSpy.Resources.ru.resx | 944 +++ .../Properties/dnSpy.Resources.zh-CN.resx | 944 +++ dnSpy/dnSpy/Scripting/ServiceLocator.cs | 60 + .../dnSpy/Search/AppCommandLineArgsHandler.cs | 184 + dnSpy/dnSpy/Search/Commands.cs | 251 + dnSpy/dnSpy/Search/FileSearcher.cs | 207 + dnSpy/dnSpy/Search/FileSearcherCreator.cs | 53 + dnSpy/dnSpy/Search/FilterSearcher.cs | 641 ++ dnSpy/dnSpy/Search/FilterSearcherOptions.cs | 39 + dnSpy/dnSpy/Search/SearchControl.xaml | 86 + dnSpy/dnSpy/Search/SearchControl.xaml.cs | 49 + dnSpy/dnSpy/Search/SearchControlVM.cs | 369 + dnSpy/dnSpy/Search/SearchManager.cs | 294 + dnSpy/dnSpy/Search/SearchResult.cs | 279 + dnSpy/dnSpy/Search/SearchResultContext.cs | 35 + dnSpy/dnSpy/Search/SearchSettings.cs | 161 + dnSpy/dnSpy/Search/SearchToolWindowContent.cs | 116 + dnSpy/dnSpy/Search/SearchType.cs | 47 + dnSpy/dnSpy/Search/SearchTypeVM.cs | 68 + .../Settings/Dialog/AppRefreshSettings.cs | 42 + .../dnSpy/Settings/Dialog/AppSettingsDlg.xaml | 53 + .../Settings/Dialog/AppSettingsDlg.xaml.cs | 49 + .../Dialog/DynamicAppSettingsTabCreator.cs | 240 + .../dnSpy/Settings/Dialog/ShowAppSettings.cs | 57 + dnSpy/dnSpy/Settings/SectionAttributes.cs | 76 + dnSpy/dnSpy/Settings/SettingsManager.cs | 75 + dnSpy/dnSpy/Settings/SettingsSection.cs | 98 + .../dnSpy/Settings/SettingsSectionCreator.cs | 80 + dnSpy/dnSpy/Settings/XmlSettingsConstants.cs | 27 + dnSpy/dnSpy/Settings/XmlSettingsReader.cs | 78 + dnSpy/dnSpy/Settings/XmlSettingsWriter.cs | 79 + dnSpy/dnSpy/Settings/XmlUtils.cs | 114 + .../dnSpy/Tabs/FileTabBackgroundConverter.cs | 43 + dnSpy/dnSpy/Tabs/TabElementScaler.cs | 172 + dnSpy/dnSpy/Tabs/TabGroup.cs | 676 ++ dnSpy/dnSpy/Tabs/TabGroupManager.cs | 413 + dnSpy/dnSpy/Tabs/TabItemImpl.cs | 176 + dnSpy/dnSpy/Tabs/TabManager.cs | 88 + dnSpy/dnSpy/Tabs/TabManagerCreator.cs | 44 + dnSpy/dnSpy/Tabs/TabUtils.cs | 40 + .../TextEditor/ContextMenuInitializer.cs | 57 + dnSpy/dnSpy/TextEditor/DnSpyTextEditor.cs | 665 ++ dnSpy/dnSpy/TextEditor/EditorPositionState.cs | 40 + dnSpy/dnSpy/TextEditor/IL.xshd | 3 + dnSpy/dnSpy/TextEditor/LogEditorCreator.cs | 45 + dnSpy/dnSpy/TextEditor/LogEditorUI.cs | 252 + dnSpy/dnSpy/TextEditor/ReplCommands.cs | 121 + dnSpy/dnSpy/TextEditor/ReplEditorCreator.cs | 46 + dnSpy/dnSpy/TextEditor/ReplEditorUI.cs | 1148 +++ dnSpy/dnSpy/TextEditor/TextEditorSettings.cs | 154 + .../dnSpy/Themes/AppCommandLineArgsHandler.cs | 50 + dnSpy/dnSpy/Themes/Color.cs | 52 + dnSpy/dnSpy/Themes/ColorInfo.cs | 190 + dnSpy/dnSpy/Themes/ColorInfos.cs | 1962 +++++ dnSpy/dnSpy/Themes/Theme.cs | 375 + dnSpy/dnSpy/Themes/ThemeColor.cs | 45 + dnSpy/dnSpy/Themes/ThemeManager.cs | 178 + dnSpy/dnSpy/Themes/ThemeSettings.cs | 73 + dnSpy/dnSpy/Themes/ThemesMenu.cs | 82 + dnSpy/dnSpy/Themes/blue.dntheme | 537 ++ dnSpy/dnSpy/Themes/dark.dntheme | 537 ++ dnSpy/dnSpy/Themes/hc.dntheme | 432 + dnSpy/dnSpy/Themes/light.dntheme | 129 + dnSpy/dnSpy/Themes/wpf.styles.templates.xaml | 5600 +++++++++++++ dnSpy/dnSpy/ToolBars/ToolBarButtonVM.cs | 63 + dnSpy/dnSpy/ToolBars/ToolBarItemContext.cs | 34 + dnSpy/dnSpy/ToolBars/ToolBarManager.cs | 263 + dnSpy/dnSpy/ToolWindows/TabContentImpl.cs | 293 + dnSpy/dnSpy/ToolWindows/ToolWindowGroup.cs | 149 + .../ToolWindows/ToolWindowGroupManager.cs | 246 + dnSpy/dnSpy/ToolWindows/ToolWindowManager.cs | 90 + .../ToolWindows/ToolWindowManagerCreator.cs | 38 + dnSpy/dnSpy/TreeView/DnSpySharpTreeNode.cs | 157 + .../TreeView/SharpTreeNodeChildrenList.cs | 118 + dnSpy/dnSpy/TreeView/TreeNodeDataImpl.cs | 50 + dnSpy/dnSpy/TreeView/TreeNodeImpl.cs | 110 + dnSpy/dnSpy/TreeView/TreeViewImpl.cs | 306 + dnSpy/dnSpy/TreeView/TreeViewManager.cs | 70 + dnSpy/dnSpy/app.manifest | 50 + dnSpy/dnSpy/dnSpy.csproj | 703 ++ 2103 files changed, 288120 insertions(+) create mode 100644 .gitattributes create mode 100644 .gitignore create mode 100644 .gitmodules create mode 160000 Libraries/ICSharpCode.AvalonEdit create mode 160000 Libraries/ICSharpCode.TreeView create mode 160000 Libraries/dnlib create mode 100644 Licenses/CREDITS.txt create mode 100644 Licenses/GPLv3.txt create mode 100644 Licenses/LICENSE.txt create mode 100644 Licenses/OtherLicenses.txt create mode 100644 Plugins/Examples/Example1.Plugin/CodeCtxMenus.cs create mode 100644 Plugins/Examples/Example1.Plugin/Example1.Plugin.csproj create mode 100644 Plugins/Examples/Example1.Plugin/Images/Assembly.png create mode 100644 Plugins/Examples/Example1.Plugin/MainMenuCommands.cs create mode 100644 Plugins/Examples/Example1.Plugin/MiscOptions.cs create mode 100644 Plugins/Examples/Example1.Plugin/MySettings.cs create mode 100644 Plugins/Examples/Example1.Plugin/MySettingsControl.xaml create mode 100644 Plugins/Examples/Example1.Plugin/MySettingsControl.xaml.cs create mode 100644 Plugins/Examples/Example1.Plugin/MySettingsTab.cs create mode 100644 Plugins/Examples/Example1.Plugin/Plugin.cs create mode 100644 Plugins/Examples/Example1.Plugin/Properties/AssemblyInfo.cs create mode 100644 Plugins/Examples/Example1.Plugin/README.md create mode 100644 Plugins/Examples/Example1.Plugin/ToolBarCommands.cs create mode 100644 Plugins/Examples/Example1.Plugin/TreeViewCtxMenus.cs create mode 100644 Plugins/Examples/Example2.Plugin/AssemblyChildNodeTabContent.cs create mode 100644 Plugins/Examples/Example2.Plugin/Example2.Plugin.csproj create mode 100644 Plugins/Examples/Example2.Plugin/Images/EntryPoint.png create mode 100644 Plugins/Examples/Example2.Plugin/Images/Strings.png create mode 100644 Plugins/Examples/Example2.Plugin/Images/TextFile.png create mode 100644 Plugins/Examples/Example2.Plugin/NewDnSpyFile.cs create mode 100644 Plugins/Examples/Example2.Plugin/Plugin.cs create mode 100644 Plugins/Examples/Example2.Plugin/Properties/AssemblyInfo.cs create mode 100644 Plugins/Examples/Example2.Plugin/README.md create mode 100644 Plugins/Examples/Example2.Plugin/Themes/resourcedict.xaml create mode 100644 Plugins/Examples/Example2.Plugin/ToolTipContentCreator.cs create mode 100644 Plugins/Examples/Example2.Plugin/ToolWindowContent.cs create mode 100644 Plugins/Examples/Example2.Plugin/ToolWindowControl.xaml create mode 100644 Plugins/Examples/Example2.Plugin/ToolWindowControl.xaml.cs create mode 100644 Plugins/Examples/Example2.Plugin/TreeNodeDataCreator.cs create mode 160000 Plugins/ILSpy.Decompiler/ICSharpCode.Decompiler create mode 160000 Plugins/ILSpy.Decompiler/NRefactory create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/AssemblyInfoTransform.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/BuilderCache.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/BuilderState.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/CSharpLanguage.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/DecompilePartialTransform.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/ThreadSafeObjectPool.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/IL/ILLanguage.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/ILAst/ILAstLanguage.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Plugin.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/AssemblyInfo.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.Designer.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.resx create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.ru.resx create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.zh-CN.resx create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/CSharpDecompilerSettingsTab.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerAppSettingsModifiedListener.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerSettingsImpl.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerSettingsTabCreator.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILAstLanguageDecompilerSettings.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILDecompilerSettingsTab.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILLanguageDecompilerSettings.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILSettings.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/LanguageDecompilerSettings.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/LanguageSettingsManager.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/SettingsConstants.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Themes/wpf.styles.templates.xaml create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/ILSpyEnvironmentProvider.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/VBLanguage.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/VBTextOutputFormatter.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/AddXmlDocTransform.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/StringLineIterator.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/SubString.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/XmlDocLine.cs create mode 100644 Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/dnSpy.Languages.ILSpy.csproj create mode 100644 Plugins/dnSpy.Analyzer/AnalyzerManager.cs create mode 100644 Plugins/dnSpy.Analyzer/AnalyzerSettings.cs create mode 100644 Plugins/dnSpy.Analyzer/AnalyzerToolWindowContent.cs create mode 100644 Plugins/dnSpy.Analyzer/AnalyzerTreeNodeDataContext.cs create mode 100644 Plugins/dnSpy.Analyzer/Commands.cs create mode 100644 Plugins/dnSpy.Analyzer/Images/Copy.png create mode 100644 Plugins/dnSpy.Analyzer/Images/Delete.png create mode 100644 Plugins/dnSpy.Analyzer/Images/Search.png create mode 100644 Plugins/dnSpy.Analyzer/Plugin.cs create mode 100644 Plugins/dnSpy.Analyzer/Properties/AssemblyInfo.cs create mode 100644 Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.Designer.cs create mode 100644 Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.resx create mode 100644 Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.ru.resx create mode 100644 Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.zh-CN.resx create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/AnalyzerTreeNodeData.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/AssemblyNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/AsyncFetchChildrenHelper.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/AttributeAppliedToNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/Commands.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/EntityNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/EventAccessorNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/EventFiredByNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/EventNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/EventOverridesNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/FieldAccessNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/FieldNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/Helpers.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/IAnalyzerTreeNodeData.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/IAnalyzerTreeNodeDataContext.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/IAsyncCancellable.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/InterfaceEventImplementedByNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/InterfaceMethodImplementedByNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/InterfacePropertyImplementedByNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/MethodNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/MethodOverridesNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/MethodUsedByNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/MethodUsesNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/ModuleNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/PropertyAccessorNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/PropertyNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/PropertyOverridesNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/ScopedWhereUsedAnalyzer.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/SearchNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/SourceRef.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/TypeExposedByNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/TypeExtensionMethodsNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/TypeInstantiationsNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/TypeNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/TypeUsedByNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeNodes/VirtualMethodUsedByNode.cs create mode 100644 Plugins/dnSpy.Analyzer/TreeTraversal.cs create mode 100644 Plugins/dnSpy.Analyzer/dnSpy.Analyzer.csproj create mode 100644 Plugins/dnSpy.AsmEditor/Assembly/AssemblyCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/AsmEditorContext.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/ClipboardDataHolder.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/CodeContextMenuHandler.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/CodeContextMenuHandlerCommandProxy.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/CommandUtils.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/ContextMenuHandler.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/DeletableNodes.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/EditMenuHandler.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/EditMenuHandlerCommandProxy.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/FileMenuHandler.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/FilesContextMenuHandler.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/IIndexedItem.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/IndexObservableCollection.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/InstructionCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/ListBoxHelperBase.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/MyObservableCollection.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/NamespaceNodeCreator.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/RefFinder.cs create mode 100644 Plugins/dnSpy.AsmEditor/Commands/RootDnSpyFileNodeCreator.cs create mode 100644 Plugins/dnSpy.AsmEditor/Converters/CilObjectConverter.cs create mode 100644 Plugins/dnSpy.AsmEditor/Converters/InstructionOperandTextBoxStyleConverter.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CAArgumentVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CANamedArgumentControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CANamedArgumentControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CANamedArgumentVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CANamedArgumentsControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CANamedArgumentsControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CANamedArgumentsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ConstantControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ConstantControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ConstantTypeControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ConstantTypeControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ConstantTypeDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ConstantTypeDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ConstantTypeVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ConstantVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/Converters/BooleanToGridrowLengthConverter.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/Converters/RadioButtonConverter.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CreateTypeSigArrayControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CreateTypeSigArrayControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CreateTypeSigArrayDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CreateTypeSigArrayDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CreateTypeSigArrayVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributeControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributeControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributeDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributeDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributeOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributeVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributesControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributesControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/CustomAttributesVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecuritiesControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecuritiesControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecuritiesVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecurityControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecurityControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecurityDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecurityDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecurityOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DeclSecurityVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/DlgUtils.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/EnumDataFieldVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamsControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamsControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/GenericParamsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ImplMapControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ImplMapControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ImplMapVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ListVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ListVMControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ListVMControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MarshalTypeControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MarshalTypeControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MarshalTypeVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberPickerDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberPickerDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberPickerVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberRefControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberRefControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberRefDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberRefDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberRefOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MemberRefVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodDefVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodDefsControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodDefsControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodDefsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodOverrideOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodOverrideVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodOverridesControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodOverridesControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodOverridesVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSigCreatorControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSigCreatorControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSigCreatorDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSigCreatorDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSigCreatorOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSigCreatorVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSpecControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSpecControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSpecDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSpecDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSpecOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/MethodSpecVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ModelUtils.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/Null.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ObjectListDataFieldVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefsControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefsControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/ParamDefsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/SecurityAttributeControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/SecurityAttributeControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/SecurityAttributeDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/SecurityAttributeDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/SecurityAttributeVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/SecurityAttributesControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/SecurityAttributesControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/SecurityAttributesVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCAControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCAControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCADlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCADlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCAOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCAVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCAsControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCAsControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeDefOrRefAndCAsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeSigCreatorControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeSigCreatorControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeSigCreatorDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeSigCreatorDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeSigCreatorOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeSigCreatorVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/DnlibDialogs/TypeSigVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Event/EventDefCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Event/EventDefOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Event/EventOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Event/EventOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Event/EventOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/ExtensionMethods.cs create mode 100644 Plugins/dnSpy.AsmEditor/Field/FieldDefCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Field/FieldDefOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Field/FieldOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Field/FieldOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Field/FieldOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/AsmEdHexDocument.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Commands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexAddressReferenceFileTabContentCreator.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexBoxFileTabContent.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexBoxUIState.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexBoxUIStateSerializer.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexBoxUndoCommand.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexBoxUndoManager.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexDocumentManager.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexTabSaver.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/HexUndoableDocumentsProvider.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/IUndoHexDocument.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/InstructionUtils.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/MDTableContextMenuCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/HexField.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/HexFileTabContent.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/HexFileTreeNodeDataFinder.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/HexNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/HexUtils.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/HexVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageCor20HeaderNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageCor20HeaderVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageDosHeaderNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageDosHeaderVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageFileHeaderNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageFileHeaderVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageOptionalHeader32Node.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageOptionalHeader32VM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageOptionalHeader64Node.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageOptionalHeader64VM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageOptionalHeaderVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageSectionHeaderNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/ImageSectionHeaderVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/MetaDataTableNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/MetaDataTableRecordNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/MetaDataTableRecordVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/MetaDataTableVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/PENode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/PETreeNodeDataCreator.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/StorageHeaderNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/StorageHeaderVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/StorageSignatureNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/StorageSignatureVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/StorageStreamNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/StorageStreamVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/TablesStreamNode.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/TablesStreamVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/TokenReferenceFileTabContentCreator.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/VirtualizedList.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/Nodes/wpf.styles.templates.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Hex/TableSorter.cs create mode 100644 Plugins/dnSpy.AsmEditor/Hex/WriteHexUndoCommand.cs create mode 100644 Plugins/dnSpy.AsmEditor/Images/AddException.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/AddLocal.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/AddNewItem.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/ArrowDown.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/ArrowUp.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/AssemblyToModule.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Binary.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/BinaryFile.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Branch.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Class.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Copy.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Cut.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Delete.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/DeleteHistory.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Field.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Generic.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/ILEditor.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/MetaData.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Method.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/ModuleFile.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/ModuleToAssembly.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NOP.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NameSpace.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewAssembly.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewAssemblyModule.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewBinary.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewClass.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewEvent.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewField.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewImage.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewMethod.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewProperty.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewResource.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/NewResourcesFile.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Open.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Paste.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Redo.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/SaveAll.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Settings.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/ToUncondBranch.png create mode 100644 Plugins/dnSpy.AsmEditor/Images/Undo.png create mode 100644 Plugins/dnSpy.AsmEditor/Method/MethodDefCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Method/MethodDefOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Method/MethodOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Method/MethodOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Method/MethodOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/BodyUtils.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/CilBodyOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/CilBodyVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/ComboBoxAttachedProps.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/ExceptionHandlerOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/ExceptionHandlerVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/ExceptionHandlersListHelper.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/FastClickButton.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/IEditOperand.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/InstructionOperandControl.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/InstructionOperandVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/InstructionOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/InstructionVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/InstructionsListHelper.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/LocalOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/LocalVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/LocalsListHelper.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/MethodBodyCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/MethodBodyControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/MethodBodyControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/MethodBodyDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/MethodBodyDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/MethodBodyOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/MethodBodyType.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/MethodBodyVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/NativeMethodBodyOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/NativeMethodBodyVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/SwitchInstructionVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/SwitchOperandControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/SwitchOperandControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/SwitchOperandDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/SwitchOperandDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/SwitchOperandVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/MethodBody/SwitchOperandsListHelper.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/ClrVersion.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/ClrVersionValues.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/ModuleCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/ModuleOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/ModuleOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Module/ModuleOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/ModuleOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/ModuleUtils.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/NetModuleOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/NetModuleOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Module/NetModuleOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Module/NetModuleOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Namespace/NamespaceCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Namespace/NamespaceDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Namespace/NamespaceDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Namespace/NamespaceVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Plugin.cs create mode 100644 Plugins/dnSpy.AsmEditor/Properties/AssemblyInfo.cs create mode 100644 Plugins/dnSpy.AsmEditor/Properties/dnSpy.AsmEditor.Resources.Designer.cs create mode 100644 Plugins/dnSpy.AsmEditor/Properties/dnSpy.AsmEditor.Resources.resx create mode 100644 Plugins/dnSpy.AsmEditor/Properties/dnSpy.AsmEditor.Resources.ru.resx create mode 100644 Plugins/dnSpy.AsmEditor/Properties/dnSpy.AsmEditor.Resources.zh-CN.resx create mode 100644 Plugins/dnSpy.AsmEditor/Property/PropertyDefCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Property/PropertyDefOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Property/PropertyOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Property/PropertyOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Property/PropertyOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageListDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageListDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageListStreamerControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageListStreamerControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageListStreamerVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageListVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageResourceElementControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageResourceElementControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageResourceElementDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageResourceElementDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageResourceElementVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ImageVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceElementControl.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceElementControl.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceElementDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceElementDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceElementOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceElementVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/ResourceVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/Resources/UserTypeVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/CharacteristicsHelper.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/DocumentSaver.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/MmapDisabler.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/ModuleSaver.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/PathUtils.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveHexOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveHexOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveHexOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveModuleCommand.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveModuleOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveModuleOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveModuleOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveModuleWindow.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveMultiModuleDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveMultiModuleDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveMultiModuleVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveOptionsType.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveSingleModuleDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/SaveModule/SaveSingleModuleDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Themes/wpf.styles.templates.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Types/TypeDefCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/Types/TypeDefOptions.cs create mode 100644 Plugins/dnSpy.AsmEditor/Types/TypeOptionsDlg.xaml create mode 100644 Plugins/dnSpy.AsmEditor/Types/TypeOptionsDlg.xaml.cs create mode 100644 Plugins/dnSpy.AsmEditor/Types/TypeOptionsVM.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/Commands.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/DnSpyFileUndoableDocumentsProvider.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/IUndoCommand.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/IUndoObject.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/IUndoableDocumentsProvider.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/ToolbarCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/UndoCommandManager.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/UndoCommandManagerEventArgs.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/UndoObject.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/UndoRedoIFileListListener.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/UndoRedoMenuCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/UndoRedo/UndoRoutedCommands.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/CreateConstantType.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/CreateMethodPropertySig.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/CreateTypeSigArray.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/DnlibTypePicker.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditCustomAttribute.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditDeclSecurity.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditGenericParam.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditImage.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditMemberRef.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditMethodDef.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditMethodOverride.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditMethodSpec.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditParamDef.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditSecurityAttribute.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/EditTypeDefOrRefAndCA.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/ICreateConstantType.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/ICreateMethodPropertySig.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/ICreateTypeSigArray.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/IDnlibTypePicker.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/IEdit.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/IOpenAssembly.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/IOpenFile.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/IOpenPublicKeyFile.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/ISelectItems.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/IShowWarningMessage.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/ITypeSigCreator.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/OpenAssembly.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/OpenFile.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/OpenPublicKeyFile.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/ShowWarningMessage.cs create mode 100644 Plugins/dnSpy.AsmEditor/ViewHelpers/TypeSigCreator.cs create mode 100644 Plugins/dnSpy.AsmEditor/dnSpy.AsmEditor.csproj create mode 100644 Plugins/dnSpy.BamlDecompiler/Annotations.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/BamlContext.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/BamlDocument.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/BamlNode.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/BamlReader.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/BamlRecords.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/BamlWriter.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/KnownMembers.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/KnownThings.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/KnownThings.g.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/KnownThings.gen.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Baml/KnownTypes.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlDecompiler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlDisassembler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlElement.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlResourceElementNode.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlResourceNodeCreator.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlSettings.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlSettings.xaml create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlTabSaverCreator.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/BamlToolTipContentCreator.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Blocks/ConstructorParametersHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Blocks/DocumentHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Blocks/ElementHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Blocks/KeyElementStartHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Blocks/PropertyArrayHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Blocks/PropertyComplexHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Blocks/PropertyDictionaryHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Blocks/PropertyListHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/AssemblyInfoHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/AttributeInfoHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/ConnectionIdHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/ConstructorParameterTypeHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/ContentPropertyHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/DefAttributeHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/DefAttributeKeyStringHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/DefAttributeKeyTypeHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/DeferableContentStartHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/LineNumberAndPositionHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/LinePositionHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/LiteralContentHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/OptimizedStaticResourceHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/PIMappingHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/PresentationOptionsAttributeHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/PropertyCustomHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/PropertyHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/PropertyTypeReferenceHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/PropertyWithConverterHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/PropertyWithExtensionHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/PropertyWithStaticResourceIdHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/TextHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/TextWithConverterHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/TypeInfoHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Handlers/Records/XmlnsPropertyHandler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/IHandlers.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/IRewritePass.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Images/XamlFile.png create mode 100644 Plugins/dnSpy.BamlDecompiler/MenuCommands.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Plugin.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Properties/AssemblyInfo.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Properties/dnSpy.BamlDecompiler.Resources.Designer.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Properties/dnSpy.BamlDecompiler.Resources.resx create mode 100644 Plugins/dnSpy.BamlDecompiler/Properties/dnSpy.BamlDecompiler.Resources.ru.resx create mode 100644 Plugins/dnSpy.BamlDecompiler/Properties/dnSpy.BamlDecompiler.Resources.zh-CN.resx create mode 100644 Plugins/dnSpy.BamlDecompiler/Rewrite/AttributeRewritePass.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Rewrite/ConnectionIdRewritePass.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Rewrite/DocumentRewritePass.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Rewrite/MarkupExtensionRewritePass.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Rewrite/XClassRewritePass.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Xaml/NamespaceMap.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Xaml/XamlExtension.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Xaml/XamlPathDeserializer.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Xaml/XamlProperty.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Xaml/XamlResourceKey.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Xaml/XamlType.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/Xaml/XamlUtils.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/XamlContext.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/XamlDecompiler.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/XmlnsDictionary.cs create mode 100644 Plugins/dnSpy.BamlDecompiler/dnSpy.BamlDecompiler.csproj create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/AppMenus.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/Breakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointColumnConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointContext.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointListSettings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointManager.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointPrinter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointSettings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointsContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointsControl.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointsControl.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointsToolWindowContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/BreakpointsVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/DebugEventBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Breakpoints/ILCodeBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CachedOutput.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/CallStackContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/CallStackControl.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/CallStackControl.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/CallStackFrameColumnConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/CallStackFrameVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/CallStackSettings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/CallStackToolWindowContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/CallStackVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/FrameUtils.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/StackFrameLine.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/StackFrameManager.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CallStack/VMPropertyChangedEventArgs.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/CodeMappings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Converters/ImageConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebugCommands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebugManager.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebugManagerCommands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebugOutputUtils.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebugRoutedCommands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebugUtils.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebuggedProcessRunningNotifier.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebuggerAppSettingsTab.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebuggerColors.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/DebuggerSettings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/AttachProcessDlg.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/AttachProcessDlg.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/AttachProcessVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/DebugCoreCLRDlg.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/DebugCoreCLRDlg.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/DebugCoreCLRVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/DebugProcessDlg.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/DebugProcessDlg.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/DebugProcessVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/ManagedProcessesFinder.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/ProcessColumnConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/ProcessContext.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/ProcessPrinter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Dialogs/ProcessVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/EvalUtils.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ClickFocusAP.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/DefaultExceptionSettings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionColumnConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionControl.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionControl.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionInfo.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionInfoKey.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionListSettings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionManager.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionPrinter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionState.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionType.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionsContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionsToolWindowContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ExceptionsVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/IGetNewExceptionName.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Exceptions/ISelectedItemsProvider.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/ILoadBeforeDebug.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/ClassLoader.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/CorModuleDefFile.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/InMemoryModuleManager.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/LastValidRids.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/LoadEverythingDlg.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/LoadEverythingDlg.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/LoadEverythingVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/MemoryModuleDefFile.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/IMModules/TreeViewUpdater.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/ISerializedDnModule.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Add.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/AssemblyExe.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/AssemblyModule.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Break.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Breakpoint.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/BreakpointMenu.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/BreakpointsWindow.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/CallStackWindow.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/ContinueDebugging.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Copy.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/CurrentLine.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/CurrentLineToolBar.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Cursor.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Delete.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/DeleteAllBreakpoints.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/DisableAllBreakpoints.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/DisableEnableBreakpoint.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/DisabledBreakpoint.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/DisassemblyWindow.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/DraggedCurrentInstructionPointer.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/EnableAllBreakpoints.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/EnumValue.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/EnumValueCompilerControlled.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/EnumValueInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/EnumValuePrivate.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/EnumValueProtected.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/EnumValueProtectedInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Exception.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/ExceptionSettings.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Field.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldCompilerControlled.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldPrivate.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldProtected.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldProtectedInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldReadOnly.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldReadOnlyCompilerControlled.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldReadOnlyInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldReadOnlyPrivate.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldReadOnlyProtected.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/FieldReadOnlyProtectedInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Filter.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/GenericParameter.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/GoToSourceCode.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Literal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/LiteralCompilerControlled.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/LiteralInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/LiteralPrivate.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/LiteralProtected.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/LiteralProtectedInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/LocalsWindow.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/MemoryWindow.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/ModulesWindow.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/OneLevelUp.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Process.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Property.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/PropertyCompilerControlled.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/PropertyInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/PropertyPrivate.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/PropertyProtected.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/PropertyProtectedInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/QuestionMark.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Refresh.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/RemoveCommand.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/RestartProcess.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Save.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Select.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/SelectedReturnLine.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/SetNextStatement.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StartDebugging.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StartWithoutDebugging.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StaticProperty.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StaticPropertyCompilerControlled.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StaticPropertyInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StaticPropertyPrivate.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StaticPropertyProtected.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StaticPropertyProtectedInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StatusError.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StepInto.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StepOut.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StepOver.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/StopProcess.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/SuperTypes.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/SuperTypesOpen.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Thread.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/UndoCheckBoxList.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/VirtualProperty.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/VirtualPropertyCompilerControlled.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/VirtualPropertyInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/VirtualPropertyPrivate.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/VirtualPropertyProtected.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/VirtualPropertyProtectedInternal.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Images/Watch.png create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/AskUser.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/EditValueControl.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/EditValueControl.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/LocalColumnConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/LocalsContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/LocalsControl.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/LocalsControl.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/LocalsSettings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/LocalsToolWindowContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/LocalsVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/MethodLocalProvider.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/ValueContext.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/ValuePrinter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/ValueStringParser.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Locals/ValueVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Logger/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Logger/OutputLogger.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Logger/OutputLoggerSettings.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/MarkedTextLine.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/MemoryContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/MemoryControl.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/MemoryControl.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/MemoryToolWindowContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/MemoryVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/MemoryWindowManager.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/MemoryWindowsHelper.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Memory/ProcessHexStream.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/MenuItemCommandProxy.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/ModuleLoader.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/ModuleColumnConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/ModulePrinter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/ModuleVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/ModulesContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/ModulesControl.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/ModulesControl.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/ModulesToolWindowContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/ModulesVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Modules/PEFilesSaver.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/NativeMethods.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/OutputConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/OutputWriterConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Plugin.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/ProcessMemoryUtils.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Properties/AssemblyInfo.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Properties/dnSpy.Debugger.Resources.Designer.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Properties/dnSpy.Debugger.Resources.resx create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Properties/dnSpy.Debugger.Resources.ru.resx create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Properties/dnSpy.Debugger.Resources.zh-CN.resx create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/AnyEventBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebugEventContext.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/Debugger.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerAppDomain.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerAssembly.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerClass.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerCode.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerEvent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerField.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerMethod.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerModule.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerProperty.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerThread.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerType.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/DebuggerValue.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/Eval.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/EventBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/IDnBreakpointHolder.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/ILBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/NativeBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/StackChain.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/StackFrame.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/TypeComparer.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Scripting/Utils.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/SerializedDnModuleCreator.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/SerializedDnToken.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/TheDebugger.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Themes/wpf.styles.templates.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/Commands.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/ThreadColumnConverter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/ThreadPrinter.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/ThreadVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/ThreadsContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/ThreadsControl.xaml create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/ThreadsControl.xaml.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/ThreadsToolWindowContent.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/Threads/ThreadsVM.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/WpfDebugMessageDispatcher.cs create mode 100644 Plugins/dnSpy.Debugger/dnSpy.Debugger/dnSpy.Debugger.csproj create mode 100644 Plugins/dnSpy.Debugger/dndbg/COM/CorDebug.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/COM/MetaData.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/COM/MetaHost.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorAssemblyDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorAssemblyRef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorDeclSecurity.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorEventDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorExportedType.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorFieldDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorFileDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorGenericParam.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorGenericParamConstraint.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorInterfaceImpl.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorManifestResource.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorMemberRef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorMethodDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorMethodSpec.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorModuleDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorModuleRef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorParamDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorPropertyDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorStandAloneSig.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorTypeDef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorTypeRef.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/CorTypeSpec.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/ICorMDTokenProvider.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/ICorModuleDefHelper.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/IProcessReader.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/ProcessBinaryReader.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/TypeUpdatedEventArgs.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/DotNet/Utils.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/AttachProcessOptions.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/BreakProcessHelper.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/BreakProcessKind.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/BreakpointList.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/COMObject.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorAppDomain.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorAssembly.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorChain.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorClass.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorCode.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorDebugExtensions.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorDebugManagedCallback.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorEval.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorEvent.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorExceptionObjectStackFrame.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorField.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorFrame.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorFunction.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorFunctionBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorMDA.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorModule.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorModuleDefHelper.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorOverride.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorProcess.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorProcessReader.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorProperty.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorStepper.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorThread.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorType.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorValue.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorValueHolder.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CorValueReader.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CordbgErrors.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/CoreCLRHelper.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebugCallbackEventArgs.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebugEventBreakpointList.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebugOptions.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebugProcessOptions.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebuggeeVersionDetector.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebuggerCollection.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebuggerEventArgs.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebuggerPauseState.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebuggerProcessState.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DebuggerState.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DisableSystemDebuggerDetection.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnAnyDebugEventBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnAppDomain.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnAssembly.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnCodeBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnDebugEventBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnDebugger.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnEval.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnILCodeBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnModule.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnNativeCodeBreakpoint.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnProcess.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DnThread.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/DndbgSignatureReader.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/ECallManager.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/IDebugMessageDispatcher.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/ILFrameIP.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/IdentifierEscaper.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/MDAPI.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/MetaDataUtils.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/NativeMethods.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/ProcessCreationFlags.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/SerializedDnModule.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/StepRange.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/TypeComparer.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/TypePrinter.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/TypePrinterUtils.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Engine/Utils.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/Properties/AssemblyInfo.cs create mode 100644 Plugins/dnSpy.Debugger/dndbg/dndbg.csproj create mode 100644 Plugins/dnSpy.Scripting.Roslyn/CSharp/CSharpContent.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/CSharp/CSharpControlVM.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/CSharp/CSharpToolWindowContent.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/CSharpInteractive.rsp create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/CachedWriter.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ClearCommand.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/Commands.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/HelpCommand.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/IScriptCommand.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/IScriptGlobalsHelper.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/PrintOptionsImpl.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ResetCommand.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/RespFileUtils.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ResponseFileReader.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ScriptContent.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ScriptControl.xaml create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ScriptControl.xaml.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ScriptControlVM.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ScriptGlobals.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Common/ScriptToolWindowContent.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Converters/ImageConverter.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/ArrowDown.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/ArrowUp.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/CSInteractiveWindow.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/ClearWindowContent.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/Copy.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/CopyItem.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/Cut.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/Paste.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/Reset.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Images/VBInteractiveWindow.png create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Plugin.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Properties/AssemblyInfo.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Properties/dnSpy.Scripting.Roslyn.Resources.Designer.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Properties/dnSpy.Scripting.Roslyn.Resources.resx create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Properties/dnSpy.Scripting.Roslyn.Resources.ru.resx create mode 100644 Plugins/dnSpy.Scripting.Roslyn/Properties/dnSpy.Scripting.Roslyn.Resources.zh-CN.resx create mode 100644 Plugins/dnSpy.Scripting.Roslyn/VisualBasic/VisualBasicContent.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/VisualBasic/VisualBasicControlVM.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/VisualBasic/VisualBasicToolWindowContent.cs create mode 100644 Plugins/dnSpy.Scripting.Roslyn/VisualBasicInteractive.rsp create mode 100644 Plugins/dnSpy.Scripting.Roslyn/dnSpy.Scripting.Roslyn.csproj create mode 100644 Plugins/dnSpy.Scripting.Roslyn/project.json create mode 100644 README.md create mode 100644 dnSpy.sln create mode 100644 dnSpy.snk create mode 100644 dnSpy/dnSpy-x86/Program.cs create mode 100644 dnSpy/dnSpy-x86/Properties/AssemblyInfo.cs create mode 100644 dnSpy/dnSpy-x86/dnSpy-x86.csproj create mode 100644 dnSpy/dnSpy.Console/Program.cs create mode 100644 dnSpy/dnSpy.Console/Properties/AssemblyInfo.cs create mode 100644 dnSpy/dnSpy.Console/Properties/dnSpy.Console.Resources.Designer.cs create mode 100644 dnSpy/dnSpy.Console/Properties/dnSpy.Console.Resources.resx create mode 100644 dnSpy/dnSpy.Console/Properties/dnSpy.Console.Resources.ru.resx create mode 100644 dnSpy/dnSpy.Console/Properties/dnSpy.Console.Resources.zh-CN.resx create mode 100644 dnSpy/dnSpy.Console/dnSpy.Console.csproj create mode 100644 dnSpy/dnSpy.Contracts/App/AppDirectories.cs create mode 100644 dnSpy/dnSpy.Contracts/App/IAppCommandLineArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/App/IAppCommandLineArgsHandler.cs create mode 100644 dnSpy/dnSpy.Contracts/App/IAppSettings.cs create mode 100644 dnSpy/dnSpy.Contracts/App/IAppStatusBar.cs create mode 100644 dnSpy/dnSpy.Contracts/App/IAppWindow.cs create mode 100644 dnSpy/dnSpy.Contracts/App/IDnSpyLoader.cs create mode 100644 dnSpy/dnSpy.Contracts/App/IMessageBoxManager.cs create mode 100644 dnSpy/dnSpy.Contracts/App/LoaderConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/App/MsgBoxButton.cs create mode 100644 dnSpy/dnSpy.Contracts/Command/ICommandHolder.cs create mode 100644 dnSpy/dnSpy.Contracts/Controls/CommandConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Controls/IFocusable.cs create mode 100644 dnSpy/dnSpy.Contracts/Controls/IWpfCommandManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Controls/IWpfCommands.cs create mode 100644 dnSpy/dnSpy.Contracts/Controls/IWpfFocusChecker.cs create mode 100644 dnSpy/dnSpy.Contracts/Controls/IWpfFocusManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Decompiler/ICodeMappings.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/DnSpyFileInfo.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/FileConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/FilenameKey.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IAnnotations.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IDnSpyDotNetFile.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IDnSpyFile.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IDnSpyFileCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IDnSpyFilenameKey.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IDnSpyPEFile.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IFileManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IFileManagerCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IFileManagerSettings.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/IMethodAnnotations.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/NotifyFileCollectionChangedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/NotifyFileCollectionType.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/FileModifiedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/FileTabReferenceResult.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IAsyncFileTabContent.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IAsyncShowResult.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileListListener.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTab.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTabContent.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTabContentFactory.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTabContentFactoryContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTabManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTabManagerSettings.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTabUIContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTabUIContextCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IFileTabUIContextLocator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/ILanguageTabContent.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IReferenceFileTabContentCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/ISaveManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/IShowContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/ITabSaver.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/ITabSaverCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/ShowTabContentEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TabConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/CodeReference.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/IDecompileNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/IDecompileNodeCollection.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/IDecompileNodeContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/IDecompileSelf.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/IIconBarCommand.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/IIconBarCommandContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/IIconBarObject.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/IMarkedTextLine.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ITextEditorUIContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ITextEditorUIContextManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ITextLineObject.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ITextLineObjectManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ITextMarker.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ITextMarkerObject.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/TextEditorConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/TextEditorUIContextListenerEvent.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/TextEditorUIContextManagerConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/TextLineObjectEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/TextLineObjectListModifiedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ToolTips/ICodeToolTipCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ToolTips/ICodeToolTipWriter.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ToolTips/IToolTipContentCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/Tabs/TextEditor/ToolTips/IToolTipContentCreatorContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/FileTVConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/FileTreeNodeActivatedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/FileTreeNodeFilterResult.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/FileTreeNodeGroupType.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/FilterType.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IAssemblyFileNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IAssemblyReferenceNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IBaseTypeFolderNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IBaseTypeNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IDerivedTypeNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IDerivedTypesFolderNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IDnSpyFileNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IDnSpyFileNodeCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IEventNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFieldNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeNodeCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeNodeData.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeNodeDataContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeNodeDataFinder.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeNodeFilter.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeNodeGroups.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeView.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeViewCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IFileTreeViewSettings.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IMessageNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IMethodNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IModuleFileNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IModuleReferenceNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/INamespaceNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IPEFileNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IPropertyNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IReferencesFolderNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IResourcesFolderNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/ITypeNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/IUnknownFileNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/MemberKind.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/NodePathName.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/NotifyFileTreeViewCollection.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/NotifyFileTreeViewCollectionChangedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IBuiltInResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IImageResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IImageResourceNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IResourceDataProvider.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IResourceElementSetNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IResourceNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IResourceNodeCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IResourceNodeFactory.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/ISerializedImageListStreamerResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/ISerializedImageResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/ISerializedResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IUnknownResourceNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/IUnknownSerializedResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/ImageListOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/ResourceData.cs create mode 100644 dnSpy/dnSpy.Contracts/Files/TreeView/Resources/ResourceDataType.cs create mode 100644 dnSpy/dnSpy.Contracts/Highlighting/ISyntaxHighlightOutput.cs create mode 100644 dnSpy/dnSpy.Contracts/Images/BackgroundType.cs create mode 100644 dnSpy/dnSpy.Contracts/Images/IDotNetImageManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Images/IImageManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Images/ImageReference.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/BamlDecompilerOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/DecompilationContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/DecompilationType.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/DecompileAssemblyInfo.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/DecompilePartialType.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/DecompileTypeBase.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/DecompilerOptionConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/IBamlDecompiler.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/IDecompilerOption.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/IDecompilerSettings.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/IDecompilerSettingsTab.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/IDecompilerSettingsTabCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/ILanguage.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/ILanguageCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/ILanguageManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/ILanguageProvider.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/ISimpleILPrinter.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/LanguageConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/SimplePrinterFlags.cs create mode 100644 dnSpy/dnSpy.Contracts/Languages/SyntaxHighlightOutputToTextOutput.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/CreatedMenuItem.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/ExportMenuAttribute.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/ExportMenuItemAttribute.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/GuidObject.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IContextMenuCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IContextMenuInitializer.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IGuidObjectsCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IMenu.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IMenuItem.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IMenuItemContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IMenuItemCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IMenuItemMetadata.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IMenuManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/IMenuMetadata.cs create mode 100644 dnSpy/dnSpy.Contracts/Menus/MenuConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Output/ICachedWriter.cs create mode 100644 dnSpy/dnSpy.Contracts/Output/IOutputManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Output/IOutputTextPane.cs create mode 100644 dnSpy/dnSpy.Contracts/Output/IOutputWriter.cs create mode 100644 dnSpy/dnSpy.Contracts/Plugin/IAutoLoaded.cs create mode 100644 dnSpy/dnSpy.Contracts/Plugin/IPlugin.cs create mode 100644 dnSpy/dnSpy.Contracts/Plugin/PluginEvent.cs create mode 100644 dnSpy/dnSpy.Contracts/Plugin/PluginInfo.cs create mode 100644 dnSpy/dnSpy.Contracts/Properties/AssemblyInfo.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/AttachOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/Box.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/BreakProcessKind.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/BreakpointKind.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ChainReason.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/CodeChunkInfo.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/CorElementType.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/CoreCLRDebugOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/DebugEventKind.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/DebugHandleType.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/DebugOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/DebugStepReason.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/DebuggerEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/DebuggerPauseState.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/DebuggerProcessState.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ExceptionObjectStackFrame.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IAnyEventBreakpoint.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IAppDomain.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IBreakpoint.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ICodeBreakpoint.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebugEventContext.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebugger.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerAssembly.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerClass.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerCode.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerEvent.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerField.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerMethod.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerModule.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerProperty.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerThread.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerType.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IDebuggerValue.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IEval.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IEventBreakpoint.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IILBreakpoint.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ILCodeKind.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ILFrameIP.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/INativeBreakpoint.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IStackChain.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/IStackFrame.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/InternalFrameType.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/MappingResult.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ModuleName.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ThreadState.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ThreadUserState.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/TypeFormatFlags.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Debugger/ValueResult.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/IOutputWritable.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/IOutputWriter.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/IServiceLocator.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Roslyn/ICachedWriter.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Roslyn/IPrintOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Roslyn/IScriptGlobals.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Roslyn/ITextPrinter.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/Roslyn/MemberDisplayFormat.cs create mode 100644 dnSpy/dnSpy.Contracts/Scripting/ScriptException.cs create mode 100644 dnSpy/dnSpy.Contracts/Search/BodyResult.cs create mode 100644 dnSpy/dnSpy.Contracts/Search/FileSearcherOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/Search/IFileSearcher.cs create mode 100644 dnSpy/dnSpy.Contracts/Search/IFileSearcherCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Search/ISearchComparer.cs create mode 100644 dnSpy/dnSpy.Contracts/Search/ISearchResult.cs create mode 100644 dnSpy/dnSpy.Contracts/Search/SearchResultEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Search/SearchTypeInfo.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/Dialog/AppSettingsConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/Dialog/IAppRefreshSettings.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/Dialog/IAppSettingsModifiedListener.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/Dialog/IAppSettingsTab.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/Dialog/IAppSettingsTabCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/Dialog/IDynamicAppSettingsTab.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/Dialog/ISimpleAppOption.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/Dialog/ISimpleAppOptionCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/ISettingsManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/ISettingsSection.cs create mode 100644 dnSpy/dnSpy.Contracts/Settings/ISettingsSectionCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/ITabContent.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/ITabGroup.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/ITabGroupManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/ITabManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/ITabManagerCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/TabContentAttachedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/TabContentVisibilityEvent.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/TabGroupCollectionChangedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/TabGroupManagerOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/TabGroupSelectedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Tabs/TabSelectedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/ColorAndText.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/ColorOffsetInfo.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/ILogEditor.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/ILogEditorCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/ILogEditorUI.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/IOutputColorWriter.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/IReplCommandHandler.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/IReplCommandInput.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/IReplEditor.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/IReplEditorCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/IReplEditorUI.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/ITextEditorSettings.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/LogEditorOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/OutputColor.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/ReplEditorOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/TextEditor/TextEditorLocation.cs create mode 100644 dnSpy/dnSpy.Contracts/Themes/ColorType.cs create mode 100644 dnSpy/dnSpy.Contracts/Themes/ITheme.cs create mode 100644 dnSpy/dnSpy.Contracts/Themes/IThemeColor.cs create mode 100644 dnSpy/dnSpy.Contracts/Themes/IThemeManager.cs create mode 100644 dnSpy/dnSpy.Contracts/Themes/ThemeChangedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/Themes/ThemeConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/ExportToolBarButtonAttribute.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/ExportToolBarItemAttribute.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/ExportToolBarObjectAttribute.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarButton.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarButtonMetadata.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarItem.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarItemContext.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarItemMetadata.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarManager.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarObject.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarObjectMetadata.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/IToolBarToggleButton.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolBars/ToolBarConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/App/AppToolWindowConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/App/AppToolWindowLocation.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/App/IMainToolWindowContentCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/App/IMainToolWindowManager.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/App/ToolWindowContentInfo.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/IToolWindowContent.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/IToolWindowGroup.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/IToolWindowGroupManager.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/IToolWindowManager.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/IToolWindowManagerCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/ToolWindowContentVisibilityEvent.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/ToolWindowGroupCollectionChangedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/ToolWindowGroupManagerOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/ToolWindowGroupSelectedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/ToolWindows/ToolWindowSelectedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/IMDTokenNode.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/ITreeNode.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/ITreeNodeData.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/ITreeNodeDataCreator.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/ITreeNodeGroup.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/ITreeView.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/ITreeViewListener.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/ITreeViewManager.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/TVConstants.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/TVNodeRemovedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/TVSelectionChangedEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/TreeNodeDataCreatorContext.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/TreeViewListenerEvent.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/TreeViewListenerEventArgs.cs create mode 100644 dnSpy/dnSpy.Contracts/TreeView/TreeViewOptions.cs create mode 100644 dnSpy/dnSpy.Contracts/dnSpy.Contracts.csproj create mode 100644 dnSpy/dnSpy.Decompiler.Shared/AddressReference.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/CodeMappings.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/Extensions.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/GenericArgumentResolver.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/IILVariable.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/IInstructionBytesReader.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/ILRange.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/ITextOutput.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/IdentifierEscaper.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/InstructionReference.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/MemberComparer.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/PlainTextOutput.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/Properties/AssemblyInfo.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/SimpleXmlParser.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/TextPosition.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/TextTokenKind.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/TokenReference.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/TypesHierarchyHelpers.cs create mode 100644 dnSpy/dnSpy.Decompiler.Shared/dnSpy.Decompiler.Shared.csproj create mode 100644 dnSpy/dnSpy.Languages/CSharp/SimpleCSharpPrinter.cs create mode 100644 dnSpy/dnSpy.Languages/FilenameUtils.cs create mode 100644 dnSpy/dnSpy.Languages/IL/ILLanguageHelper.cs create mode 100644 dnSpy/dnSpy.Languages/IL/InstructionBytesReader.cs create mode 100644 dnSpy/dnSpy.Languages/IL/InstructionUtils.cs create mode 100644 dnSpy/dnSpy.Languages/IL/ModifiedInstructionBytesReader.cs create mode 100644 dnSpy/dnSpy.Languages/IL/OriginalInstructionBytesReader.cs create mode 100644 dnSpy/dnSpy.Languages/Language.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/AppConfigProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ApplicationIcon.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ApplicationManifest.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/AssemblyInfoProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/BamlResourceProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/BuildAction.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/DecompileContext.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/DefaultNamespaceFinder.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/DotNetUtils.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/FileUtils.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/FilenameCreator.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/IJob.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/IMSBuildProgressListener.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/IMSBuildProjectWriterLogger.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/MSBuildProjectCreator.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/NoMSBuildProjectWriterLogger.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/Project.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ProjectCreatorOptions.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ProjectModuleOptions.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ProjectVersion.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ProjectWriter.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/RawEmbeddedResourceProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ResXProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ResourceNameCreator.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/ResourceProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/SatelliteAssemblyFinder.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/SettingsProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/SettingsTypeProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/SolutionWriter.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/SplashScreenProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/TypeProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/WinFormsProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/MSBuild/XamlTypeProjectFile.cs create mode 100644 dnSpy/dnSpy.Languages/Properties/AssemblyInfo.cs create mode 100644 dnSpy/dnSpy.Languages/Properties/Languages.Resources.Designer.cs create mode 100644 dnSpy/dnSpy.Languages/Properties/Languages.Resources.resx create mode 100644 dnSpy/dnSpy.Languages/Properties/Languages.Resources.ru.resx create mode 100644 dnSpy/dnSpy.Languages/Properties/Languages.Resources.zh-CN.resx create mode 100644 dnSpy/dnSpy.Languages/Settings/DecompilerOption.cs create mode 100644 dnSpy/dnSpy.Languages/TargetFrameworkInfo.cs create mode 100644 dnSpy/dnSpy.Languages/TargetFrameworkUtils.cs create mode 100644 dnSpy/dnSpy.Languages/dnSpy.Languages.csproj create mode 100644 dnSpy/dnSpy.Roslyn.Shared/ClassificationTypeConverter.cs create mode 100644 dnSpy/dnSpy.Roslyn.Shared/Properties/AssemblyInfo.cs create mode 100644 dnSpy/dnSpy.Roslyn.Shared/dnSpy.Roslyn.Shared.csproj create mode 100644 dnSpy/dnSpy.Roslyn.Shared/project.json create mode 100644 dnSpy/dnSpy.Shared/App/MsgBox.cs create mode 100644 dnSpy/dnSpy.Shared/AvalonEdit/AvalonEditSearchPanelLocalization.cs create mode 100644 dnSpy/dnSpy.Shared/AvalonEdit/ExtensionMethods.cs create mode 100644 dnSpy/dnSpy.Shared/Controls/FastTextBlock.cs create mode 100644 dnSpy/dnSpy.Shared/Controls/FastTreeNodeView.cs create mode 100644 dnSpy/dnSpy.Shared/Controls/FontUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Controls/MetroWindow.cs create mode 100644 dnSpy/dnSpy.Shared/Controls/SysMenuButton.cs create mode 100644 dnSpy/dnSpy.Shared/Controls/TabButton.cs create mode 100644 dnSpy/dnSpy.Shared/Controls/WinSysButton.cs create mode 100644 dnSpy/dnSpy.Shared/Controls/WindowBase.cs create mode 100644 dnSpy/dnSpy.Shared/Decompiler/AvalonEditTextOutput.cs create mode 100644 dnSpy/dnSpy.Shared/Decompiler/ISmartTextOutput.cs create mode 100644 dnSpy/dnSpy.Shared/Decompiler/OutputLengthExceededException.cs create mode 100644 dnSpy/dnSpy.Shared/Files/AnnotationsImpl.cs create mode 100644 dnSpy/dnSpy.Shared/Files/DnSpyFile.cs create mode 100644 dnSpy/dnSpy.Shared/Files/GacInfo.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/FileTreeNodeData.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/NodePrinter.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/Deserializer.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/GuessFileType.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/ImageResourceUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/ResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/ResourceNode.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/ResourceUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/SaveResources.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/SerializationUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/SerializedImageListStreamerUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/SerializedImageUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Files/TreeView/Resources/SerializedResourceElementNode.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/DnHexBox.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/GoToOffsetDlg.xaml create mode 100644 dnSpy/dnSpy.Shared/Hex/GoToOffsetDlg.xaml.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/GoToOffsetVM.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/HexBoxCommands.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/HexBoxThemeHelper.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/HexEditorAppSettingsTab.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/HexEditorSettings.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/LocalHexSettings.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/LocalSettingsDlg.xaml create mode 100644 dnSpy/dnSpy.Shared/Hex/LocalSettingsDlg.xaml.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/LocalSettingsVM.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/MDUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/SelectDlg.xaml create mode 100644 dnSpy/dnSpy.Shared/Hex/SelectDlg.xaml.cs create mode 100644 dnSpy/dnSpy.Shared/Hex/SelectVM.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/AsciiEncoding.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/ByteArrayHexStream.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/CachedHexStream.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/ClipboardUtils.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/DataFormatter.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexBox.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexBoxPosition.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexBoxPositionKind.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexBoxState.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexBoxWriteEventArgs.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexCaret.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexDocument.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexDocumentModifiedEventArgs.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexLine.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexLineLayer.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexLinePart.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexLineTextSource.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexPositionUI.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexSelection.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexTextParagraphProperties.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexTextRunProperties.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HexWriteType.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/HtmlClipboardFormatWriter.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/IHexLayer.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/IHexStream.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/ISimpleHexStream.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/NumberUtils.cs create mode 100644 dnSpy/dnSpy.Shared/HexEditor/SelectionLayer.cs create mode 100644 dnSpy/dnSpy.Shared/Highlighting/ISyntaxHighlightOutput.cs create mode 100644 dnSpy/dnSpy.Shared/Highlighting/NameUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Highlighting/NoSyntaxHighlightOutput.cs create mode 100644 dnSpy/dnSpy.Shared/Highlighting/SyntaxHighlighter.cs create mode 100644 dnSpy/dnSpy.Shared/Highlighting/TextTokenInfo.cs create mode 100644 dnSpy/dnSpy.Shared/Highlighting/UISyntaxHighlighter.cs create mode 100644 dnSpy/dnSpy.Shared/Images/Copy.png create mode 100644 dnSpy/dnSpy.Shared/Images/Fill.png create mode 100644 dnSpy/dnSpy.Shared/Images/ImageManagerExtensionMethods.cs create mode 100644 dnSpy/dnSpy.Shared/Images/Paste.png create mode 100644 dnSpy/dnSpy.Shared/Images/dnSpy.ico create mode 100644 dnSpy/dnSpy.Shared/Languages/StringBuilderExtensions.cs create mode 100644 dnSpy/dnSpy.Shared/Languages/XmlDoc/XmlDocKeyProvider.cs create mode 100644 dnSpy/dnSpy.Shared/Languages/XmlDoc/XmlDocLoader.cs create mode 100644 dnSpy/dnSpy.Shared/Languages/XmlDoc/XmlDocRenderer.cs create mode 100644 dnSpy/dnSpy.Shared/Languages/XmlDoc/XmlDocumentationProvider.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/Converters/BooleanToThicknessConverter.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/Converters/FontSizeConverter.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/Converters/NegateBooleanConverter.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/DataFieldVM.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/Dialogs/ProgressDlg.xaml create mode 100644 dnSpy/dnSpy.Shared/MVVM/Dialogs/ProgressDlg.xaml.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/Dialogs/ProgressVM.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/EnumVM.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/IInitializeDataTemplate.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/InitDataTemplateAP.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/IsDraggableAP.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/ListVM.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/NumberVMUtils.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/PickDirectory.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/PickFilename.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/PickSaveFilename.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/RelayCommand.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/UIUtils.cs create mode 100644 dnSpy/dnSpy.Shared/MVVM/ViewModelBase.cs create mode 100644 dnSpy/dnSpy.Shared/Menus/MenuItemBase.cs create mode 100644 dnSpy/dnSpy.Shared/Menus/MenuItemCommand.cs create mode 100644 dnSpy/dnSpy.Shared/Properties/AssemblyInfo.cs create mode 100644 dnSpy/dnSpy.Shared/Properties/dnSpy.Shared.Resources.Designer.cs create mode 100644 dnSpy/dnSpy.Shared/Properties/dnSpy.Shared.Resources.resx create mode 100644 dnSpy/dnSpy.Shared/Properties/dnSpy.Shared.Resources.ru.resx create mode 100644 dnSpy/dnSpy.Shared/Properties/dnSpy.Shared.Resources.zh-CN.resx create mode 100644 dnSpy/dnSpy.Shared/Resources/ResourceHelper.cs create mode 100644 dnSpy/dnSpy.Shared/Scripting/UIUtils.cs create mode 100644 dnSpy/dnSpy.Shared/Search/ChainFileTreeNodeFilter.cs create mode 100644 dnSpy/dnSpy.Shared/Search/DelayedAction.cs create mode 100644 dnSpy/dnSpy.Shared/Search/EntryPointFileTreeNodeFilter.cs create mode 100644 dnSpy/dnSpy.Shared/Search/FileTreeNodeFilterBase.cs create mode 100644 dnSpy/dnSpy.Shared/Search/FilterNothingFileTreeNodeFilter.cs create mode 100644 dnSpy/dnSpy.Shared/Search/FlagsFileTreeNodeFilter.cs create mode 100644 dnSpy/dnSpy.Shared/Search/NamespaceRef.cs create mode 100644 dnSpy/dnSpy.Shared/Search/NamespaceSearchResult.cs create mode 100644 dnSpy/dnSpy.Shared/Search/SameAssemblyFileTreeNodeFilter.cs create mode 100644 dnSpy/dnSpy.Shared/Search/SameModuleFileTreeNodeFilter.cs create mode 100644 dnSpy/dnSpy.Shared/Search/SearchComparers.cs create mode 100644 dnSpy/dnSpy.Shared/Search/ShowNothingFileTreeNodeFilterBase.cs create mode 100644 dnSpy/dnSpy.Shared/Search/VisibleMembersFlags.cs create mode 100644 dnSpy/dnSpy.Shared/Settings/Dialog/SimpleAppOption.cs create mode 100644 dnSpy/dnSpy.Shared/Themes/ExtensionMethods.cs create mode 100644 dnSpy/dnSpy.Shared/Themes/wpf.styles.templates.xaml create mode 100644 dnSpy/dnSpy.Shared/ToolBars/ToolBarButtonBase.cs create mode 100644 dnSpy/dnSpy.Shared/ToolBars/ToolBarButtonCommand.cs create mode 100644 dnSpy/dnSpy.Shared/ToolBars/ToolBarObjectBase.cs create mode 100644 dnSpy/dnSpy.Shared/TreeView/AsyncNodeCreator.cs create mode 100644 dnSpy/dnSpy.Shared/TreeView/TreeNodeData.cs create mode 100644 dnSpy/dnSpy.Shared/dnSpy.Shared.csproj create mode 100644 dnSpy/dnSpy/App.config create mode 100644 dnSpy/dnSpy/Controls/IStackedContentChild.cs create mode 100644 dnSpy/dnSpy/Controls/StackedContent.cs create mode 100644 dnSpy/dnSpy/Controls/StackedContentState.cs create mode 100644 dnSpy/dnSpy/Controls/WpfCommandManager.cs create mode 100644 dnSpy/dnSpy/Controls/WpfCommands.cs create mode 100644 dnSpy/dnSpy/Controls/WpfFocusManager.cs create mode 100644 dnSpy/dnSpy/Converters/ImageConverter.cs create mode 100644 dnSpy/dnSpy/Culture/Commands.cs create mode 100644 dnSpy/dnSpy/Culture/CultureManager.cs create mode 100644 dnSpy/dnSpy/Culture/CultureSettings.cs create mode 100644 dnSpy/dnSpy/Culture/LanguageInfo.cs create mode 100644 dnSpy/dnSpy/Decompiler/CodeMappings.cs create mode 100644 dnSpy/dnSpy/Decompiler/DecompilerSettingsTab.cs create mode 100644 dnSpy/dnSpy/Events/WeakEventList.cs create mode 100644 dnSpy/dnSpy/FileLists/DOTNET Framework v3.5 Client.FileList.xml create mode 100644 dnSpy/dnSpy/FileLists/DOTNET Framework v4.0 Client.FileList.xml create mode 100644 dnSpy/dnSpy/Files/AssemblyResolver.cs create mode 100644 dnSpy/dnSpy/Files/DefaultDnSpyFileCreator.cs create mode 100644 dnSpy/dnSpy/Files/DefaultDnSpyFileLoader.cs create mode 100644 dnSpy/dnSpy/Files/FileLoader.cs create mode 100644 dnSpy/dnSpy/Files/FileManager.cs create mode 100644 dnSpy/dnSpy/Files/FileManagerAppSettingsModifiedListener.cs create mode 100644 dnSpy/dnSpy/Files/FileManagerCreator.cs create mode 100644 dnSpy/dnSpy/Files/FileManagerOptionCreator.cs create mode 100644 dnSpy/dnSpy/Files/FileManagerSettings.cs create mode 100644 dnSpy/dnSpy/Files/IDnSpyFileLoader.cs create mode 100644 dnSpy/dnSpy/Files/MethodAnnotations.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/AppCommandLineArgsHandler.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/AsyncShowResult.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Commands.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/CopyTokenCommand.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/DecompilationCache.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/DefaultDecompileNode.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/DefaultFileList.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/ExportToProjectDlg.xaml create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/ExportToProjectDlg.xaml.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/ExportToProjectSettings.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/ExportToProjectVM.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/FileListColumnConverter.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/FileListPrinter.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/FileListVM.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/GACFileColumnConverter.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/GACFileFinder.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/GACFilePrinter.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/GACFileVM.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/OpenFileListDlg.xaml create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/OpenFileListDlg.xaml.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/OpenFileListVM.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/OpenFromGACDlg.xaml create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/OpenFromGACDlg.xaml.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/OpenFromGACVM.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/TabColumnConverter.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/TabPrinter.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/TabVM.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/TabsDlg.xaml create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/TabsDlg.xaml.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/TabsVM.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Dialogs/TabsVMSettings.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/DnSpyFileInfoSerializer.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/EntryPointCommands.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileList.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileListLoader.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileListManager.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTabContentFactoryContext.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTabContentFactoryManager.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTabManager.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTabManagerLoader.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTabManagerSettings.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTabSerializer.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTabUIContextLocator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTabUIContextLocatorCreator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/FileTreeNodeDecompiler.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/GoToTokenCommand.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/IDecompilationCache.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/IFileTabUIContextLocatorCreator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/MiscOptions.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/NavigationCommands.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/NodeDecompiler.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/NodeReferenceFileTabContentCreator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/NodeTabSaver.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/NullObjects.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/RedecompileTabs.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/RefreshResourcesCommand.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/ResourceCommands.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/SaveCommands.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/SaveManager.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/SearchMsdnCommand.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/SerializedTabs.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/Settings/DisplaySettingsTab.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TabCommands.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TabContentImpl.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TabHistory.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/Commands.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/DecompileFileTabContent.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/DecompileNodeContext.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/IconBarCommandManager.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/IconBarMargin.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/ReferenceElementGenerator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/TextEditorControl.xaml create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/TextEditorControl.xaml.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/TextEditorUIContext.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/TextEditorUIContextCreator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/TextEditorUIContextManagerImpl.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/TextLineObjectManager.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/TextMarkerService.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/ToolTips/CodeToolTipCreator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/ToolTips/CodeToolTipManager.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/ToolTips/CodeToolTipSettings.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/ToolTips/CodeToolTipWriter.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/ToolTips/DnlibReferenceToolTipContentCreator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/ToolTips/ToolTipContentCreatorContext.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/ToolTips/ToolTipHelper.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/UIElementGenerator.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/WaitAdorner.xaml create mode 100644 dnSpy/dnSpy/Files/Tabs/TextEditor/WaitAdorner.xaml.cs create mode 100644 dnSpy/dnSpy/Files/Tabs/TreeNodeReferenceFileTabContentCreator.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/AssemblyFileNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/AssemblyReferenceNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/BaseTypeFolderNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/BaseTypeNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/DefaultDnSpyFileNodeCreator.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/DerivedTypeNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/DerivedTypesFinder.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/DerivedTypesFolderNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/DnSpyFileNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/EventNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/FieldNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/FileTreeNodeDataContext.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/FileTreeNodeGroups.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/FileTreeView.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/FileTreeViewAppSettingsModifiedListener.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/FileTreeViewCreator.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/FileTreeViewSettings.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/MessageNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/MethodNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/ModuleFileNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/ModuleReferenceNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/NamespaceNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/PEFileNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/PropertyNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/ReferencesFolderNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/Resources/BuiltInResourceElementNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/Resources/ImageResourceNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/Resources/ResourceElementSetNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/Resources/ResourceNodeFactory.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/Resources/SerializedImageListStreamerResourceElementNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/Resources/SerializedImageResourceElementNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/Resources/UnknownResourceNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/Resources/UnknownSerializedResourceElementNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/ResourcesFolderNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/RootNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/TypeNode.cs create mode 100644 dnSpy/dnSpy/Files/TreeView/UnknownFileNode.cs create mode 100644 dnSpy/dnSpy/Images/Assembly.png create mode 100644 dnSpy/dnSpy/Images/AssemblyExe.png create mode 100644 dnSpy/dnSpy/Images/AssemblyModule.png create mode 100644 dnSpy/dnSpy/Images/AssemblyReference.png create mode 100644 dnSpy/dnSpy/Images/AssemblyWarning.png create mode 100644 dnSpy/dnSpy/Images/Backward.png create mode 100644 dnSpy/dnSpy/Images/BaseTypeClosed.png create mode 100644 dnSpy/dnSpy/Images/BaseTypeOpened.png create mode 100644 dnSpy/dnSpy/Images/Binary.png create mode 100644 dnSpy/dnSpy/Images/CSharpFile.png create mode 100644 dnSpy/dnSpy/Images/Class.png create mode 100644 dnSpy/dnSpy/Images/ClassInternal.png create mode 100644 dnSpy/dnSpy/Images/ClassPrivate.png create mode 100644 dnSpy/dnSpy/Images/ClassProtected.png create mode 100644 dnSpy/dnSpy/Images/ClassProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/ClearWindowContent.png create mode 100644 dnSpy/dnSpy/Images/Close.png create mode 100644 dnSpy/dnSpy/Images/CloseAll.png create mode 100644 dnSpy/dnSpy/Images/CloseDocuments.png create mode 100644 dnSpy/dnSpy/Images/Constructor.png create mode 100644 dnSpy/dnSpy/Images/ConstructorCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/ConstructorInternal.png create mode 100644 dnSpy/dnSpy/Images/ConstructorPrivate.png create mode 100644 dnSpy/dnSpy/Images/ConstructorProtected.png create mode 100644 dnSpy/dnSpy/Images/ConstructorProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Copy.png create mode 100644 dnSpy/dnSpy/Images/Delegate.png create mode 100644 dnSpy/dnSpy/Images/DelegateInternal.png create mode 100644 dnSpy/dnSpy/Images/DelegatePrivate.png create mode 100644 dnSpy/dnSpy/Images/DelegateProtected.png create mode 100644 dnSpy/dnSpy/Images/DelegateProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/DerivedTypesClosed.png create mode 100644 dnSpy/dnSpy/Images/DerivedTypesOpened.png create mode 100644 dnSpy/dnSpy/Images/DotNetImageManager.cs create mode 100644 dnSpy/dnSpy/Images/EntryPoint.png create mode 100644 dnSpy/dnSpy/Images/Enum.png create mode 100644 dnSpy/dnSpy/Images/EnumInternal.png create mode 100644 dnSpy/dnSpy/Images/EnumPrivate.png create mode 100644 dnSpy/dnSpy/Images/EnumProtected.png create mode 100644 dnSpy/dnSpy/Images/EnumProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/EnumValue.png create mode 100644 dnSpy/dnSpy/Images/EnumValueCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/EnumValueInternal.png create mode 100644 dnSpy/dnSpy/Images/EnumValuePrivate.png create mode 100644 dnSpy/dnSpy/Images/EnumValueProtected.png create mode 100644 dnSpy/dnSpy/Images/EnumValueProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Event.png create mode 100644 dnSpy/dnSpy/Images/EventCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/EventInternal.png create mode 100644 dnSpy/dnSpy/Images/EventPrivate.png create mode 100644 dnSpy/dnSpy/Images/EventProtected.png create mode 100644 dnSpy/dnSpy/Images/EventProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Exception.png create mode 100644 dnSpy/dnSpy/Images/ExceptionInternal.png create mode 100644 dnSpy/dnSpy/Images/ExceptionPrivate.png create mode 100644 dnSpy/dnSpy/Images/ExceptionProtected.png create mode 100644 dnSpy/dnSpy/Images/ExceptionProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/ExtensionMethod.png create mode 100644 dnSpy/dnSpy/Images/ExtensionMethodCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/ExtensionMethodInternal.png create mode 100644 dnSpy/dnSpy/Images/ExtensionMethodPrivate.png create mode 100644 dnSpy/dnSpy/Images/ExtensionMethodProtected.png create mode 100644 dnSpy/dnSpy/Images/ExtensionMethodProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Field.png create mode 100644 dnSpy/dnSpy/Images/FieldCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/FieldInternal.png create mode 100644 dnSpy/dnSpy/Images/FieldPrivate.png create mode 100644 dnSpy/dnSpy/Images/FieldProtected.png create mode 100644 dnSpy/dnSpy/Images/FieldProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/FieldReadOnly.png create mode 100644 dnSpy/dnSpy/Images/FieldReadOnlyCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/FieldReadOnlyInternal.png create mode 100644 dnSpy/dnSpy/Images/FieldReadOnlyPrivate.png create mode 100644 dnSpy/dnSpy/Images/FieldReadOnlyProtected.png create mode 100644 dnSpy/dnSpy/Images/FieldReadOnlyProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Find.png create mode 100644 dnSpy/dnSpy/Images/FolderClosed.png create mode 100644 dnSpy/dnSpy/Images/FolderOpened.png create mode 100644 dnSpy/dnSpy/Images/Forward.png create mode 100644 dnSpy/dnSpy/Images/FullScreen.png create mode 100644 dnSpy/dnSpy/Images/Generic.png create mode 100644 dnSpy/dnSpy/Images/GenericInternal.png create mode 100644 dnSpy/dnSpy/Images/GenericParameter.png create mode 100644 dnSpy/dnSpy/Images/GenericPrivate.png create mode 100644 dnSpy/dnSpy/Images/GenericProtected.png create mode 100644 dnSpy/dnSpy/Images/GenericProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/HorizontalTabGroup.png create mode 100644 dnSpy/dnSpy/Images/ImageFile.png create mode 100644 dnSpy/dnSpy/Images/ImageManager.cs create mode 100644 dnSpy/dnSpy/Images/Interface.png create mode 100644 dnSpy/dnSpy/Images/InterfaceInternal.png create mode 100644 dnSpy/dnSpy/Images/InterfacePrivate.png create mode 100644 dnSpy/dnSpy/Images/InterfaceProtected.png create mode 100644 dnSpy/dnSpy/Images/InterfaceProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Library.png create mode 100644 dnSpy/dnSpy/Images/Literal.png create mode 100644 dnSpy/dnSpy/Images/LiteralCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/LiteralInternal.png create mode 100644 dnSpy/dnSpy/Images/LiteralPrivate.png create mode 100644 dnSpy/dnSpy/Images/LiteralProtected.png create mode 100644 dnSpy/dnSpy/Images/LiteralProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Local.png create mode 100644 dnSpy/dnSpy/Images/MarkUpTag.png create mode 100644 dnSpy/dnSpy/Images/Method.png create mode 100644 dnSpy/dnSpy/Images/MethodCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/MethodInternal.png create mode 100644 dnSpy/dnSpy/Images/MethodPrivate.png create mode 100644 dnSpy/dnSpy/Images/MethodProtected.png create mode 100644 dnSpy/dnSpy/Images/MethodProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/ModuleReference.png create mode 100644 dnSpy/dnSpy/Images/Namespace.png create mode 100644 dnSpy/dnSpy/Images/NewWindow.png create mode 100644 dnSpy/dnSpy/Images/OneLevelUp.png create mode 100644 dnSpy/dnSpy/Images/Open.png create mode 100644 dnSpy/dnSpy/Images/Operator.png create mode 100644 dnSpy/dnSpy/Images/OperatorCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/OperatorInternal.png create mode 100644 dnSpy/dnSpy/Images/OperatorPrivate.png create mode 100644 dnSpy/dnSpy/Images/OperatorProtected.png create mode 100644 dnSpy/dnSpy/Images/OperatorProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Output.png create mode 100644 dnSpy/dnSpy/Images/PInvokeMethod.png create mode 100644 dnSpy/dnSpy/Images/PInvokeMethodCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/PInvokeMethodInternal.png create mode 100644 dnSpy/dnSpy/Images/PInvokeMethodPrivate.png create mode 100644 dnSpy/dnSpy/Images/PInvokeMethodProtected.png create mode 100644 dnSpy/dnSpy/Images/PInvokeMethodProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Parameter.png create mode 100644 dnSpy/dnSpy/Images/Property.png create mode 100644 dnSpy/dnSpy/Images/PropertyCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/PropertyInternal.png create mode 100644 dnSpy/dnSpy/Images/PropertyPrivate.png create mode 100644 dnSpy/dnSpy/Images/PropertyProtected.png create mode 100644 dnSpy/dnSpy/Images/PropertyProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/ReferenceFolder.png create mode 100644 dnSpy/dnSpy/Images/Resource.png create mode 100644 dnSpy/dnSpy/Images/ResourcesFile.png create mode 100644 dnSpy/dnSpy/Images/Save.png create mode 100644 dnSpy/dnSpy/Images/Search.png create mode 100644 dnSpy/dnSpy/Images/Settings.png create mode 100644 dnSpy/dnSpy/Images/Solution.png create mode 100644 dnSpy/dnSpy/Images/StaticClass.png create mode 100644 dnSpy/dnSpy/Images/StaticEvent.png create mode 100644 dnSpy/dnSpy/Images/StaticEventCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/StaticEventInternal.png create mode 100644 dnSpy/dnSpy/Images/StaticEventPrivate.png create mode 100644 dnSpy/dnSpy/Images/StaticEventProtected.png create mode 100644 dnSpy/dnSpy/Images/StaticEventProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/StaticMethod.png create mode 100644 dnSpy/dnSpy/Images/StaticMethodCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/StaticMethodInternal.png create mode 100644 dnSpy/dnSpy/Images/StaticMethodPrivate.png create mode 100644 dnSpy/dnSpy/Images/StaticMethodProtected.png create mode 100644 dnSpy/dnSpy/Images/StaticMethodProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/StaticProperty.png create mode 100644 dnSpy/dnSpy/Images/StaticPropertyCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/StaticPropertyInternal.png create mode 100644 dnSpy/dnSpy/Images/StaticPropertyPrivate.png create mode 100644 dnSpy/dnSpy/Images/StaticPropertyProtected.png create mode 100644 dnSpy/dnSpy/Images/StaticPropertyProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/Strings.png create mode 100644 dnSpy/dnSpy/Images/Struct.png create mode 100644 dnSpy/dnSpy/Images/StructInternal.png create mode 100644 dnSpy/dnSpy/Images/StructPrivate.png create mode 100644 dnSpy/dnSpy/Images/StructProtected.png create mode 100644 dnSpy/dnSpy/Images/StructProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/TextFile.png create mode 100644 dnSpy/dnSpy/Images/ThemedImageCreator.cs create mode 100644 dnSpy/dnSpy/Images/UserDefinedDataType.png create mode 100644 dnSpy/dnSpy/Images/VerticalTabGroup.png create mode 100644 dnSpy/dnSpy/Images/VirtualEvent.png create mode 100644 dnSpy/dnSpy/Images/VirtualEventCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/VirtualEventInternal.png create mode 100644 dnSpy/dnSpy/Images/VirtualEventPrivate.png create mode 100644 dnSpy/dnSpy/Images/VirtualEventProtected.png create mode 100644 dnSpy/dnSpy/Images/VirtualEventProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/VirtualMethod.png create mode 100644 dnSpy/dnSpy/Images/VirtualMethodCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/VirtualMethodInternal.png create mode 100644 dnSpy/dnSpy/Images/VirtualMethodPrivate.png create mode 100644 dnSpy/dnSpy/Images/VirtualMethodProtected.png create mode 100644 dnSpy/dnSpy/Images/VirtualMethodProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/VirtualProperty.png create mode 100644 dnSpy/dnSpy/Images/VirtualPropertyCompilerControlled.png create mode 100644 dnSpy/dnSpy/Images/VirtualPropertyInternal.png create mode 100644 dnSpy/dnSpy/Images/VirtualPropertyPrivate.png create mode 100644 dnSpy/dnSpy/Images/VirtualPropertyProtected.png create mode 100644 dnSpy/dnSpy/Images/VirtualPropertyProtectedInternal.png create mode 100644 dnSpy/dnSpy/Images/VisualBasicFile.png create mode 100644 dnSpy/dnSpy/Images/WordWrap.png create mode 100644 dnSpy/dnSpy/Images/XamlFile.png create mode 100644 dnSpy/dnSpy/Images/XmlFile.png create mode 100644 dnSpy/dnSpy/Images/XsdFile.png create mode 100644 dnSpy/dnSpy/Images/XsltFile.png create mode 100644 dnSpy/dnSpy/Images/dnSpy-Big.png create mode 100644 dnSpy/dnSpy/Images/dnSpy.ico create mode 100644 dnSpy/dnSpy/Images/tableviewnameonly.png create mode 100644 dnSpy/dnSpy/Images/toolstrippanelbottom.png create mode 100644 dnSpy/dnSpy/Images/toolstrippanelleft.png create mode 100644 dnSpy/dnSpy/Images/toolstrippanelright.png create mode 100644 dnSpy/dnSpy/Images/toolstrippaneltop.png create mode 100644 dnSpy/dnSpy/Languages/DummyLanguage.cs create mode 100644 dnSpy/dnSpy/Languages/LanguageManager.cs create mode 100644 dnSpy/dnSpy/Languages/LanguageManagerSettings.cs create mode 100644 dnSpy/dnSpy/MVVM/InitializeDataTemplateContextMenu.cs create mode 100644 dnSpy/dnSpy/MainApp/AboutCommands.cs create mode 100644 dnSpy/dnSpy/MainApp/AboutScreen.cs create mode 100644 dnSpy/dnSpy/MainApp/App.xaml create mode 100644 dnSpy/dnSpy/MainApp/App.xaml.cs create mode 100644 dnSpy/dnSpy/MainApp/AppCommandLineArgs.cs create mode 100644 dnSpy/dnSpy/MainApp/AppCommandLineArgsHandler.cs create mode 100644 dnSpy/dnSpy/MainApp/AppSettings.cs create mode 100644 dnSpy/dnSpy/MainApp/AppStatusBar.cs create mode 100644 dnSpy/dnSpy/MainApp/AppToolBar.cs create mode 100644 dnSpy/dnSpy/MainApp/AppWindow.cs create mode 100644 dnSpy/dnSpy/MainApp/AskDlg.xaml create mode 100644 dnSpy/dnSpy/MainApp/AskDlg.xaml.cs create mode 100644 dnSpy/dnSpy/MainApp/AskVM.cs create mode 100644 dnSpy/dnSpy/MainApp/DnSpyLoaderControl.xaml create mode 100644 dnSpy/dnSpy/MainApp/DnSpyLoaderControl.xaml.cs create mode 100644 dnSpy/dnSpy/MainApp/DnSpyLoaderManager.cs create mode 100644 dnSpy/dnSpy/MainApp/FileTreeViewWindowContent.cs create mode 100644 dnSpy/dnSpy/MainApp/MainToolWindowManagerCommands.cs create mode 100644 dnSpy/dnSpy/MainApp/MainWindow.xaml create mode 100644 dnSpy/dnSpy/MainApp/MainWindow.xaml.cs create mode 100644 dnSpy/dnSpy/MainApp/MainWindowControl.cs create mode 100644 dnSpy/dnSpy/MainApp/MessageBoxManager.cs create mode 100644 dnSpy/dnSpy/MainApp/MiscOptions.cs create mode 100644 dnSpy/dnSpy/MainApp/MsgBoxDlg.xaml create mode 100644 dnSpy/dnSpy/MainApp/MsgBoxDlg.xaml.cs create mode 100644 dnSpy/dnSpy/MainApp/MsgBoxVM.cs create mode 100644 dnSpy/dnSpy/MainApp/SavedWindowState.cs create mode 100644 dnSpy/dnSpy/MainApp/StartUpClass.cs create mode 100644 dnSpy/dnSpy/MainApp/ToolBarCommands.cs create mode 100644 dnSpy/dnSpy/MainApp/ViewCommands.cs create mode 100644 dnSpy/dnSpy/Menus/AppMenus.cs create mode 100644 dnSpy/dnSpy/Menus/ContextMenuCreator.cs create mode 100644 dnSpy/dnSpy/Menus/MenuItemContext.cs create mode 100644 dnSpy/dnSpy/Menus/MenuManager.cs create mode 100644 dnSpy/dnSpy/Output/CachedWriter.cs create mode 100644 dnSpy/dnSpy/Output/Commands.cs create mode 100644 dnSpy/dnSpy/Output/NotPresentOutputWriter.cs create mode 100644 dnSpy/dnSpy/Output/NullOutputTextPane.cs create mode 100644 dnSpy/dnSpy/Output/OutputBufferVM.cs create mode 100644 dnSpy/dnSpy/Output/OutputCommands.cs create mode 100644 dnSpy/dnSpy/Output/OutputContent.cs create mode 100644 dnSpy/dnSpy/Output/OutputControl.xaml create mode 100644 dnSpy/dnSpy/Output/OutputControl.xaml.cs create mode 100644 dnSpy/dnSpy/Output/OutputManager.cs create mode 100644 dnSpy/dnSpy/Output/OutputManagerSettings.cs create mode 100644 dnSpy/dnSpy/Output/OutputToolWindowContent.cs create mode 100644 dnSpy/dnSpy/Plugin/LoadedPlugin.cs create mode 100644 dnSpy/dnSpy/Plugin/PluginConfig.cs create mode 100644 dnSpy/dnSpy/Plugin/PluginConfigReader.cs create mode 100644 dnSpy/dnSpy/Plugin/PluginManager.cs create mode 100644 dnSpy/dnSpy/Properties/AssemblyInfo.Shared.cs create mode 100644 dnSpy/dnSpy/Properties/AssemblyInfo.cs create mode 100644 dnSpy/dnSpy/Properties/dnSpy.Resources.Designer.cs create mode 100644 dnSpy/dnSpy/Properties/dnSpy.Resources.resx create mode 100644 dnSpy/dnSpy/Properties/dnSpy.Resources.ru.resx create mode 100644 dnSpy/dnSpy/Properties/dnSpy.Resources.zh-CN.resx create mode 100644 dnSpy/dnSpy/Scripting/ServiceLocator.cs create mode 100644 dnSpy/dnSpy/Search/AppCommandLineArgsHandler.cs create mode 100644 dnSpy/dnSpy/Search/Commands.cs create mode 100644 dnSpy/dnSpy/Search/FileSearcher.cs create mode 100644 dnSpy/dnSpy/Search/FileSearcherCreator.cs create mode 100644 dnSpy/dnSpy/Search/FilterSearcher.cs create mode 100644 dnSpy/dnSpy/Search/FilterSearcherOptions.cs create mode 100644 dnSpy/dnSpy/Search/SearchControl.xaml create mode 100644 dnSpy/dnSpy/Search/SearchControl.xaml.cs create mode 100644 dnSpy/dnSpy/Search/SearchControlVM.cs create mode 100644 dnSpy/dnSpy/Search/SearchManager.cs create mode 100644 dnSpy/dnSpy/Search/SearchResult.cs create mode 100644 dnSpy/dnSpy/Search/SearchResultContext.cs create mode 100644 dnSpy/dnSpy/Search/SearchSettings.cs create mode 100644 dnSpy/dnSpy/Search/SearchToolWindowContent.cs create mode 100644 dnSpy/dnSpy/Search/SearchType.cs create mode 100644 dnSpy/dnSpy/Search/SearchTypeVM.cs create mode 100644 dnSpy/dnSpy/Settings/Dialog/AppRefreshSettings.cs create mode 100644 dnSpy/dnSpy/Settings/Dialog/AppSettingsDlg.xaml create mode 100644 dnSpy/dnSpy/Settings/Dialog/AppSettingsDlg.xaml.cs create mode 100644 dnSpy/dnSpy/Settings/Dialog/DynamicAppSettingsTabCreator.cs create mode 100644 dnSpy/dnSpy/Settings/Dialog/ShowAppSettings.cs create mode 100644 dnSpy/dnSpy/Settings/SectionAttributes.cs create mode 100644 dnSpy/dnSpy/Settings/SettingsManager.cs create mode 100644 dnSpy/dnSpy/Settings/SettingsSection.cs create mode 100644 dnSpy/dnSpy/Settings/SettingsSectionCreator.cs create mode 100644 dnSpy/dnSpy/Settings/XmlSettingsConstants.cs create mode 100644 dnSpy/dnSpy/Settings/XmlSettingsReader.cs create mode 100644 dnSpy/dnSpy/Settings/XmlSettingsWriter.cs create mode 100644 dnSpy/dnSpy/Settings/XmlUtils.cs create mode 100644 dnSpy/dnSpy/Tabs/FileTabBackgroundConverter.cs create mode 100644 dnSpy/dnSpy/Tabs/TabElementScaler.cs create mode 100644 dnSpy/dnSpy/Tabs/TabGroup.cs create mode 100644 dnSpy/dnSpy/Tabs/TabGroupManager.cs create mode 100644 dnSpy/dnSpy/Tabs/TabItemImpl.cs create mode 100644 dnSpy/dnSpy/Tabs/TabManager.cs create mode 100644 dnSpy/dnSpy/Tabs/TabManagerCreator.cs create mode 100644 dnSpy/dnSpy/Tabs/TabUtils.cs create mode 100644 dnSpy/dnSpy/TextEditor/ContextMenuInitializer.cs create mode 100644 dnSpy/dnSpy/TextEditor/DnSpyTextEditor.cs create mode 100644 dnSpy/dnSpy/TextEditor/EditorPositionState.cs create mode 100644 dnSpy/dnSpy/TextEditor/IL.xshd create mode 100644 dnSpy/dnSpy/TextEditor/LogEditorCreator.cs create mode 100644 dnSpy/dnSpy/TextEditor/LogEditorUI.cs create mode 100644 dnSpy/dnSpy/TextEditor/ReplCommands.cs create mode 100644 dnSpy/dnSpy/TextEditor/ReplEditorCreator.cs create mode 100644 dnSpy/dnSpy/TextEditor/ReplEditorUI.cs create mode 100644 dnSpy/dnSpy/TextEditor/TextEditorSettings.cs create mode 100644 dnSpy/dnSpy/Themes/AppCommandLineArgsHandler.cs create mode 100644 dnSpy/dnSpy/Themes/Color.cs create mode 100644 dnSpy/dnSpy/Themes/ColorInfo.cs create mode 100644 dnSpy/dnSpy/Themes/ColorInfos.cs create mode 100644 dnSpy/dnSpy/Themes/Theme.cs create mode 100644 dnSpy/dnSpy/Themes/ThemeColor.cs create mode 100644 dnSpy/dnSpy/Themes/ThemeManager.cs create mode 100644 dnSpy/dnSpy/Themes/ThemeSettings.cs create mode 100644 dnSpy/dnSpy/Themes/ThemesMenu.cs create mode 100644 dnSpy/dnSpy/Themes/blue.dntheme create mode 100644 dnSpy/dnSpy/Themes/dark.dntheme create mode 100644 dnSpy/dnSpy/Themes/hc.dntheme create mode 100644 dnSpy/dnSpy/Themes/light.dntheme create mode 100644 dnSpy/dnSpy/Themes/wpf.styles.templates.xaml create mode 100644 dnSpy/dnSpy/ToolBars/ToolBarButtonVM.cs create mode 100644 dnSpy/dnSpy/ToolBars/ToolBarItemContext.cs create mode 100644 dnSpy/dnSpy/ToolBars/ToolBarManager.cs create mode 100644 dnSpy/dnSpy/ToolWindows/TabContentImpl.cs create mode 100644 dnSpy/dnSpy/ToolWindows/ToolWindowGroup.cs create mode 100644 dnSpy/dnSpy/ToolWindows/ToolWindowGroupManager.cs create mode 100644 dnSpy/dnSpy/ToolWindows/ToolWindowManager.cs create mode 100644 dnSpy/dnSpy/ToolWindows/ToolWindowManagerCreator.cs create mode 100644 dnSpy/dnSpy/TreeView/DnSpySharpTreeNode.cs create mode 100644 dnSpy/dnSpy/TreeView/SharpTreeNodeChildrenList.cs create mode 100644 dnSpy/dnSpy/TreeView/TreeNodeDataImpl.cs create mode 100644 dnSpy/dnSpy/TreeView/TreeNodeImpl.cs create mode 100644 dnSpy/dnSpy/TreeView/TreeViewImpl.cs create mode 100644 dnSpy/dnSpy/TreeView/TreeViewManager.cs create mode 100644 dnSpy/dnSpy/app.manifest create mode 100644 dnSpy/dnSpy/dnSpy.csproj diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 000000000..03177af52 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,4 @@ +* text=auto +*.cs text diff=csharp +*.sln text eol=crlf +*.csproj text eol=crlf diff --git a/.gitignore b/.gitignore new file mode 100644 index 000000000..e56a49e98 --- /dev/null +++ b/.gitignore @@ -0,0 +1,12 @@ +.vs/ +bin/ +obj/ +*.suo +*.user +_ReSharper*/ +*.ReSharper +*.patch +/packages +*.ide/ +*.tmp_proj +project.lock.json diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 000000000..197cf0ee2 --- /dev/null +++ b/.gitmodules @@ -0,0 +1,15 @@ +[submodule "Libraries/dnlib"] + path = Libraries/dnlib + url = https://github.com/0xd4d/dnlib.git +[submodule "Plugins/ILSpy.Decompiler/NRefactory"] + path = Plugins/ILSpy.Decompiler/NRefactory + url = https://github.com/0xd4d/nrefactory.git +[submodule "Libraries/ICSharpCode.AvalonEdit"] + path = Libraries/ICSharpCode.AvalonEdit + url = https://github.com/0xd4d/avalonedit.git +[submodule "Libraries/ICSharpCode.TreeView"] + path = Libraries/ICSharpCode.TreeView + url = git@bitbucket.org:0xd4d/icsharpcode.treeview.git +[submodule "Plugins/ILSpy.Decompiler/ICSharpCode.Decompiler"] + path = Plugins/ILSpy.Decompiler/ICSharpCode.Decompiler + url = git@bitbucket.org:0xd4d/icsharpcode.decompiler.git diff --git a/Libraries/ICSharpCode.AvalonEdit b/Libraries/ICSharpCode.AvalonEdit new file mode 160000 index 000000000..f5647dd96 --- /dev/null +++ b/Libraries/ICSharpCode.AvalonEdit @@ -0,0 +1 @@ +Subproject commit f5647dd96cdf2f15d0dcf487cd267d2c24ec84fb diff --git a/Libraries/ICSharpCode.TreeView b/Libraries/ICSharpCode.TreeView new file mode 160000 index 000000000..d1e06e0c3 --- /dev/null +++ b/Libraries/ICSharpCode.TreeView @@ -0,0 +1 @@ +Subproject commit d1e06e0c3d03cab3a28f2532e920475a61241923 diff --git a/Libraries/dnlib b/Libraries/dnlib new file mode 160000 index 000000000..f77429ddc --- /dev/null +++ b/Libraries/dnlib @@ -0,0 +1 @@ +Subproject commit f77429ddcbe7594cf346fc17638a7f2a327aa55f diff --git a/Licenses/CREDITS.txt b/Licenses/CREDITS.txt new file mode 100644 index 000000000..c2c858b24 --- /dev/null +++ b/Licenses/CREDITS.txt @@ -0,0 +1,31 @@ +dnSpy credits: + + 0xd4d + Ki + + +ILSpy decompiler and analyzer credits: + + Daniel Grunwald + David Srbecky + Ed Harvey + Siegfried Pammer + Artur Zgodzinski + Eusebiu Marcu + Pent Ploompuu + Ki + 0xd4d + + +Translators: + +Chinese Simplified + Ulysses Wu + YanJun Sun + iFish + SquallATF + linkinshi + +Russian + Igor + Konctantin diff --git a/Licenses/GPLv3.txt b/Licenses/GPLv3.txt new file mode 100644 index 000000000..94a9ed024 --- /dev/null +++ b/Licenses/GPLv3.txt @@ -0,0 +1,674 @@ + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU Affero General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. diff --git a/Licenses/LICENSE.txt b/Licenses/LICENSE.txt new file mode 100644 index 000000000..32e7ecca3 --- /dev/null +++ b/Licenses/LICENSE.txt @@ -0,0 +1,18 @@ +dnSpy is released under the GPLv3 license, see GPLv3.txt for more information. + + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . diff --git a/Licenses/OtherLicenses.txt b/Licenses/OtherLicenses.txt new file mode 100644 index 000000000..ae1c20a62 --- /dev/null +++ b/Licenses/OtherLicenses.txt @@ -0,0 +1,73 @@ +Original licenses of code or other libraries used by dnSpy. Some or all of them have been modified and are now released under the GPLv3 license, like dnSpy. The following license info is the original licenses. + +*********************************************************************************** +dnlib: + +Copyright (C) 2012-2016 de4dot@gmail.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. + +*********************************************************************************** +BAML Decompiler: + + Copyright (c) 2015 Ki + + 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. + +*********************************************************************************** +Analyzer: +AvalonEdit: +ICSharpCode.Decompiler: +ICSharpCode.NRefactory: +ICSharpCode.TreeView: + +Copyright (c) 2011-2014 AlphaSierraPapa for the SharpDevelop team + +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. diff --git a/Plugins/Examples/Example1.Plugin/CodeCtxMenus.cs b/Plugins/Examples/Example1.Plugin/CodeCtxMenus.cs new file mode 100644 index 000000000..73280b0ac --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/CodeCtxMenus.cs @@ -0,0 +1,168 @@ +using System; +using System.ComponentModel.Composition; +using System.Runtime.InteropServices; +using System.Windows; +using System.Windows.Input; +using dnlib.DotNet; +using dnSpy.Contracts.Controls; +using dnSpy.Contracts.Files.Tabs.TextEditor; +using dnSpy.Contracts.Menus; +using dnSpy.Contracts.Plugin; +using dnSpy.Shared.Menus; + +// Adds menu items to the text editor context menu +// If you have many similar commands, it's better to create a base class and derive from +// MenuItemBase instead of MenuItemBase, see TreeViewCtxMenus.cs for an example. + +namespace Example1.Plugin { + static class Constants { + //TODO: Use your own guids + // The first number is the order of the group, and the guid is the guid of the group, + // see eg. dnSpy.Contracts.Menus.MenuConstants.GROUP_CTX_CODE_HEX etc + public const string GROUP_TEXTEDITOR = "20000,3567EC95-E68E-44CE-932C-98A686FDCACF"; + public const string GROUP_TREEVIEW = "20000,77ACC18E-D8EB-483B-8D93-3581574B8891"; + } + + // This gets loaded by dnSpy and is used to add the Ctrl+Alt+Q command + [ExportAutoLoaded] + sealed class CommandLoader : IAutoLoaded { + static readonly RoutedCommand Option1Command = new RoutedCommand("Option1Command", typeof(CommandLoader)); + + [ImportingConstructor] + CommandLoader(IWpfCommandManager wpfCommandManager, MySettings mySettings) { + var cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_TEXTEDITOR_UICONTEXT); + // This command will be added to all text editors + cmds.Add(Option1Command, + (s, e) => mySettings.BoolOption1 = !mySettings.BoolOption1, + (s, e) => e.CanExecute = true, + ModifierKeys.Control | ModifierKeys.Alt, Key.Q); + } + } + + [ExportMenuItem(Header = "Option 1", InputGestureText = "Ctrl+Alt+Q", Group = Constants.GROUP_TEXTEDITOR, Order = 0)] + sealed class TextEditorCommand1 : MenuItemBase { + readonly MySettings mySettings; + + [ImportingConstructor] + TextEditorCommand1(MySettings mySettings) { + this.mySettings = mySettings; + } + + public override bool IsChecked(IMenuItemContext context) { + return mySettings.BoolOption1; + } + + public override void Execute(IMenuItemContext context) { + // Toggle value + mySettings.BoolOption1 = !mySettings.BoolOption1; + } + + public override bool IsVisible(IMenuItemContext context) { + // Only show this in the text editor + return context.CreatorObject.Guid == new Guid(MenuConstants.GUIDOBJ_TEXTEDITORCONTROL_GUID); + } + } + + [ExportMenuItem(Header = "Option 2", Group = Constants.GROUP_TEXTEDITOR, Order = 10)] + sealed class TextEditorCommand2 : MenuItemBase { + readonly MySettings mySettings; + + [ImportingConstructor] + TextEditorCommand2(MySettings mySettings) { + this.mySettings = mySettings; + } + + public override bool IsChecked(IMenuItemContext context) { + return mySettings.BoolOption2; + } + + public override void Execute(IMenuItemContext context) { + // Toggle value + mySettings.BoolOption2 = !mySettings.BoolOption2; + } + + public override bool IsVisible(IMenuItemContext context) { + // Only show this in the text editor + return context.CreatorObject.Guid == new Guid(MenuConstants.GUIDOBJ_TEXTEDITORCONTROL_GUID); + } + } + + [ExportMenuItem(Group = Constants.GROUP_TEXTEDITOR, Order = 20)] + sealed class TextEditorCommand3 : MenuItemBase { + public override void Execute(IMenuItemContext context) { + var md = GetTokenObj(context); + if (md != null) { + try { + Clipboard.SetText(string.Format("{0:X8}", md.MDToken.Raw)); + } + catch (ExternalException) { } + } + } + + public override string GetHeader(IMenuItemContext context) { + var md = GetTokenObj(context); + if (md == null) + return "Copy token"; + return string.Format("Copy token {0:X8}", md.MDToken.Raw); + } + + IMDTokenProvider GetTokenObj(IMenuItemContext context) { + // Only show this in the text editor + if (context.CreatorObject.Guid != new Guid(MenuConstants.GUIDOBJ_TEXTEDITORCONTROL_GUID)) + return null; + + // All references in the text editor are stored in CodeReferences + var codeRef = context.Find(); + if (codeRef == null) + return null; + + return codeRef.Reference as IMDTokenProvider; + } + + public override bool IsVisible(IMenuItemContext context) { + // Only show this in the text editor + return context.CreatorObject.Guid == new Guid(MenuConstants.GUIDOBJ_TEXTEDITORCONTROL_GUID); + } + + public override bool IsEnabled(IMenuItemContext context) { + return GetTokenObj(context) != null; + } + } + + [ExportMenuItem(Group = Constants.GROUP_TEXTEDITOR, Order = 30)] + sealed class TextEditorCommand4 : MenuItemBase { + public override void Execute(IMenuItemContext context) { + var uiContext = GetUIContext(context); + if (uiContext != null) { + try { + Clipboard.SetText(string.Format("Line,col: {0},{1}", uiContext.Location.Line, uiContext.Location.Column)); + } + catch (ExternalException) { } + } + } + + public override string GetHeader(IMenuItemContext context) { + var uiContext = GetUIContext(context); + if (uiContext == null) + return "Copy line and column"; + return string.Format("Copy line,col {0},{1}", uiContext.Location.Line, uiContext.Location.Column); + } + + ITextEditorUIContext GetUIContext(IMenuItemContext context) { + // Only show this in the text editor + if (context.CreatorObject.Guid != new Guid(MenuConstants.GUIDOBJ_TEXTEDITORCONTROL_GUID)) + return null; + + return context.Find(); + } + + public override bool IsVisible(IMenuItemContext context) { + // Only show this in the text editor + return context.CreatorObject.Guid == new Guid(MenuConstants.GUIDOBJ_TEXTEDITORCONTROL_GUID); + } + + public override bool IsEnabled(IMenuItemContext context) { + return GetUIContext(context) != null; + } + } +} diff --git a/Plugins/Examples/Example1.Plugin/Example1.Plugin.csproj b/Plugins/Examples/Example1.Plugin/Example1.Plugin.csproj new file mode 100644 index 000000000..98a28ee2a --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/Example1.Plugin.csproj @@ -0,0 +1,91 @@ + + + + + Debug + AnyCPU + {B24AAB0F-CA85-4D85-8B46-10D634896E2A} + Library + Properties + Example1.Plugin + Example1.Plugin + v4.6 + 512 + + + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + 1685 + + + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + 1685 + + + + + + + + + + + + + + + + + MySettingsControl.xaml + + + + + + + + + + {fdfc1237-143f-4919-8318-4926901f4639} + dnlib + + + {9b234472-0e22-428c-9345-c8d9ee5e06af} + dnSpy.Contracts + + + {7e7c2cf8-2057-4eaa-9dad-ab3022cf4037} + dnSpy.Shared + + + + + + + + Designer + MSBuild:Compile + + + + + + + + \ No newline at end of file diff --git a/Plugins/Examples/Example1.Plugin/Images/Assembly.png b/Plugins/Examples/Example1.Plugin/Images/Assembly.png new file mode 100644 index 0000000000000000000000000000000000000000..b9022cb439102ecda5d9bb6911b941e8de71893a GIT binary patch literal 153 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`oCO|{#S9F5he4R}c>anMprE&> zi(^Pd+}TMRc^MQqSZ4PAEf18Adb`g+>Y?f}f4!1&-c7S+mg+}0uA0}-py_;ITH#Hj xyd{4;0=#Gc3}(n^OfY2JQFphdQT*gRhN+ Create() { + // Create a textbox showing our StringOption3 value. Classes that can be used: + // SimpleAppOptionCheckBox + // SimpleAppOptionButton + // SimpleAppOptionTextBox + // SimpleAppOptionUserContent + yield return new SimpleAppOptionTextBox(mySettings.StringOption3, (saveSettings, appRefreshSettings, newValue) => { + // this is false if the user canceled + if (saveSettings) + mySettings.StringOption3 = newValue; + }) { + Order = AppSettingsConstants.ORDER_MISC_USENEWRENDERER + 1, + Text = "Some String", + }; + } + } +} diff --git a/Plugins/Examples/Example1.Plugin/MySettings.cs b/Plugins/Examples/Example1.Plugin/MySettings.cs new file mode 100644 index 000000000..22b427788 --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/MySettings.cs @@ -0,0 +1,100 @@ +using System; +using System.ComponentModel.Composition; +using dnSpy.Contracts.Settings; +using dnSpy.Shared.MVVM; + +// Reads and writes the plugin settings + +namespace Example1.Plugin { + class MySettings : ViewModelBase { + // overridden by the global settings class. Hooking the PropertyChanged event could be used too + protected virtual void OnModified() { + } + + public bool BoolOption1 { + get { return boolOption1; } + set { + if (boolOption1 != value) { + boolOption1 = value; + OnPropertyChanged("BoolOption1"); + OnModified(); + } + } + } + bool boolOption1 = true; + + public bool BoolOption2 { + get { return boolOption2; } + set { + if (boolOption2 != value) { + boolOption2 = value; + OnPropertyChanged("BoolOption2"); + OnModified(); + } + } + } + bool boolOption2 = false; + + public string StringOption3 { + get { return stringOption3; } + set { + if (stringOption3 != value) { + stringOption3 = value; + OnPropertyChanged("StringOption3"); + OnModified(); + } + } + } + string stringOption3 = string.Empty; + + public MySettings Clone() { + return CopyTo(new MySettings()); + } + + public MySettings CopyTo(MySettings other) { + other.BoolOption1 = this.BoolOption1; + other.BoolOption2 = this.BoolOption2; + other.StringOption3 = this.StringOption3; + return other; + } + } + + // Export this class so it can be imported by other classes in this plugin + [Export(typeof(MySettings))] + sealed class MySettingsImpl : MySettings { + //TODO: Use your own guid + static readonly Guid SETTINGS_GUID = new Guid("A308405D-0DF5-4C56-8B1E-8CE7BA6365E1"); + + readonly ISettingsManager settingsManager; + + // Tell MEF to pass in the required ISettingsManager instance exported by dnSpy + [ImportingConstructor] + MySettingsImpl(ISettingsManager settingsManager) { + this.settingsManager = settingsManager; + + // Read the settings from the file or use the default values if our settings haven't + // been saved to it yet. + + this.disableSave = true; + var sect = settingsManager.GetOrCreateSection(SETTINGS_GUID); + BoolOption1 = sect.Attribute("BoolOption1") ?? BoolOption1; + BoolOption2 = sect.Attribute("BoolOption2") ?? BoolOption2; + StringOption3 = sect.Attribute("StringOption3") ?? StringOption3; + this.disableSave = false; + } + readonly bool disableSave; + + // Called by the base class + protected override void OnModified() { + if (disableSave) + return; + + // Save the settings + + var sect = settingsManager.RecreateSection(SETTINGS_GUID); + sect.Attribute("BoolOption1", BoolOption1); + sect.Attribute("BoolOption2", BoolOption2); + sect.Attribute("StringOption3", StringOption3); + } + } +} diff --git a/Plugins/Examples/Example1.Plugin/MySettingsControl.xaml b/Plugins/Examples/Example1.Plugin/MySettingsControl.xaml new file mode 100644 index 000000000..ceb693e6f --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/MySettingsControl.xaml @@ -0,0 +1,13 @@ + + + + + + diff --git a/Plugins/Examples/Example1.Plugin/MySettingsControl.xaml.cs b/Plugins/Examples/Example1.Plugin/MySettingsControl.xaml.cs new file mode 100644 index 000000000..5b7c1ea45 --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/MySettingsControl.xaml.cs @@ -0,0 +1,9 @@ +using System.Windows.Controls; + +namespace Example1.Plugin { + public partial class MySettingsControl : UserControl { + public MySettingsControl() { + InitializeComponent(); + } + } +} diff --git a/Plugins/Examples/Example1.Plugin/MySettingsTab.cs b/Plugins/Examples/Example1.Plugin/MySettingsTab.cs new file mode 100644 index 000000000..1b2407b5b --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/MySettingsTab.cs @@ -0,0 +1,65 @@ +using System.Collections.Generic; +using System.ComponentModel.Composition; +using dnSpy.Contracts.Settings.Dialog; + +// Adds an options dialog box tab showing settings saved in MySettings + +namespace Example1.Plugin { + // This instance gets called by dnSpy to create the tab each time the user opens the options dialog + [Export(typeof(IAppSettingsTabCreator))] // Tell MEF we're exporting this instance + sealed class MyAppSettingsTabCreator : IAppSettingsTabCreator { + readonly MySettings mySettings; + + // This constructor gets the single MySettingsImpl instance exported by MySettingsImpl in MySettings.cs + [ImportingConstructor] + MyAppSettingsTabCreator(MySettings mySettings) { + this.mySettings = mySettings; + } + + public IEnumerable Create() { + // We only create one tab + yield return new MyAppSettingsTab(mySettings); + } + } + + sealed class MyAppSettingsTab : IAppSettingsTab { + // The order of the tab, let's place it after the debugger tab + public double Order { + get { return AppSettingsConstants.ORDER_DEBUGGER_TAB_DISPLAY + 0.1; } + } + + public string Title { + get { return "MySettings"; } + } + + // This is the content shown in the tab. It should be a WPF object (eg. a UserControl) or a + // ViewModel with a DataTemplate defined in a resource dictionary. + public object UIObject { + get { + if (uiObject == null) { + uiObject = new MySettingsControl(); + uiObject.DataContext = newSettings; + } + return uiObject; + } + } + MySettingsControl uiObject; + + readonly MySettings globalSettings; + readonly MySettings newSettings; + + public MyAppSettingsTab(MySettings mySettings) { + this.globalSettings = mySettings; + this.newSettings = mySettings.Clone(); + } + + public void OnClosed(bool saveSettings, IAppRefreshSettings appRefreshSettings) { + // Check if user canceled + if (!saveSettings) + return; + + // OK was pressed, save the settings + newSettings.CopyTo(globalSettings); + } + } +} diff --git a/Plugins/Examples/Example1.Plugin/Plugin.cs b/Plugins/Examples/Example1.Plugin/Plugin.cs new file mode 100644 index 000000000..97ea2ccc1 --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/Plugin.cs @@ -0,0 +1,28 @@ +using System.Collections.Generic; +using dnSpy.Contracts.Plugin; + +// Each plugin should export one class implementing IPlugin + +namespace Example1.Plugin { + [ExportPlugin] + sealed class Plugin : IPlugin { + public IEnumerable MergedResourceDictionaries { + get { + // We don't have any extra resource dictionaries + yield break; + } + } + + public PluginInfo PluginInfo { + get { + return new PluginInfo { + ShortDescription = "Example1 plugin", + }; + } + } + + public void OnEvent(PluginEvent @event, object obj) { + // We don't care about any events + } + } +} diff --git a/Plugins/Examples/Example1.Plugin/Properties/AssemblyInfo.cs b/Plugins/Examples/Example1.Plugin/Properties/AssemblyInfo.cs new file mode 100644 index 000000000..a3a73ec24 --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/Properties/AssemblyInfo.cs @@ -0,0 +1,35 @@ +using System.Reflection; +using System.Runtime.InteropServices; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("Example1.Plugin")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("Example1.Plugin")] +[assembly: AssemblyCopyright("Copyright © 2015")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM components. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("b24aab0f-ca85-4d85-8b46-10d634896e2a")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +// You can specify all the values or you can default the Build and Revision Numbers +// by using the '*' as shown below: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/Plugins/Examples/Example1.Plugin/README.md b/Plugins/Examples/Example1.Plugin/README.md new file mode 100644 index 000000000..f3b186b9c --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/README.md @@ -0,0 +1,10 @@ + +This plugin shows how to do the basic things. It: + +- Reads and writes settings (MySettings.cs) +- Adds a tab to the options dialog box showing some of the options (MySettingsTab.cs) +- Adds a textbox to the Misc tab (MiscOptions.cs) +- Adds options to the text editor's context menu and a Ctrl+Alt+Q keyboard shortcut (CodeCtxMenus.cs) +- Adds treeview context menus (TreeViewCtxMenus.cs) +- Adds a "_Plugin" menu and menu items and a View menu command (MainMenuCommands.cs) +- Adds a button and a combobox to the toolbar (ToolBarCommands.cs) diff --git a/Plugins/Examples/Example1.Plugin/ToolBarCommands.cs b/Plugins/Examples/Example1.Plugin/ToolBarCommands.cs new file mode 100644 index 000000000..ca338de45 --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/ToolBarCommands.cs @@ -0,0 +1,42 @@ +using System.Windows; +using System.Windows.Controls; +using dnSpy.Contracts.ToolBars; +using dnSpy.Shared.ToolBars; + +// Adds a toolbar button and combobox between the asm editor and debugger toolbar items + +namespace Example1.Plugin { + static class TBConstants { + //TODO: Use your own guid + // Place it between the asm editor and debugger, see dnSpy.Contracts.ToolBars.ToolBarConstants: + // GROUP_APP_TB_MAIN_ASMED_UNDO = "4000,6351DBFC-6D8D-4847-B3F2-BC376912B9C2" + // GROUP_APP_TB_MAIN_DEBUG = "5000,A0AFBC69-B6D1-46FE-96C8-EC380DEBE9AA" + public const string GROUP_APP_TB_PLUGIN = "4500,AF461C50-6E91-41B8-9771-0BAE9B77BC69"; + } + + [ExportToolBarButton(Icon = "Assembly", ToolTip = "Click Me", Group = TBConstants.GROUP_APP_TB_PLUGIN, Order = 0)] + sealed class TBCommand1 : ToolBarButtonBase { + public override void Execute(IToolBarItemContext context) { + dnSpy.Shared.App.MsgBox.Instance.Show("Command #1"); + } + } + + [ExportToolBarObject(Group = TBConstants.GROUP_APP_TB_PLUGIN, Order = 10)] + sealed class TBCommand2 : ToolBarObjectBase { + readonly ComboBox comboBox; + + TBCommand2() { + this.comboBox = new ComboBox(); + this.comboBox.Width = 100; + this.comboBox.Items.Add("Item #1"); + this.comboBox.Items.Add("Item #2"); + this.comboBox.Items.Add("Item #3"); + this.comboBox.Items.Add("Item #4"); + this.comboBox.SelectedIndex = 1; + } + + public override object GetUIObject(IToolBarItemContext context, IInputElement commandTarget) { + return comboBox; + } + } +} diff --git a/Plugins/Examples/Example1.Plugin/TreeViewCtxMenus.cs b/Plugins/Examples/Example1.Plugin/TreeViewCtxMenus.cs new file mode 100644 index 000000000..5c7c3e688 --- /dev/null +++ b/Plugins/Examples/Example1.Plugin/TreeViewCtxMenus.cs @@ -0,0 +1,160 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Runtime.InteropServices; +using System.Windows; +using dnlib.DotNet.Emit; +using dnSpy.Contracts.Files.TreeView; +using dnSpy.Contracts.Menus; +using dnSpy.Contracts.TreeView; +using dnSpy.Shared.Menus; + +// Adds a couple of commands to the file treeview context menu. +// Since there are several commands using the same state, MenuItemBase is used +// as the base class so the context is created once and shared by all commands. + +namespace Example1.Plugin { + sealed class TVContext { + public readonly bool SomeValue; + public readonly IFileTreeNodeData[] Nodes; + + public TVContext(bool someValue, IEnumerable nodes) { + this.SomeValue = someValue; + this.Nodes = nodes.ToArray(); + } + } + + abstract class TVCtxMenuCommand : MenuItemBase { + protected sealed override object CachedContextKey { + get { return ContextKey; } + } + static readonly object ContextKey = new object(); + + protected sealed override TVContext CreateContext(IMenuItemContext context) { + // Make sure it's the file treeview + if (context.CreatorObject.Guid != new Guid(MenuConstants.GUIDOBJ_FILES_TREEVIEW_GUID)) + return null; + + // Extract the data needed by the context + var nodes = context.Find(); + if (nodes == null) + return null; + var newNodes = nodes.OfType(); + + bool someValue = true; + return new TVContext(someValue, newNodes); + } + } + + [ExportMenuItem(Header = "Command #1", Group = Constants.GROUP_TREEVIEW, Order = 0)] + sealed class TVCommand1 : TVCtxMenuCommand { + public override void Execute(TVContext context) { + dnSpy.Shared.App.MsgBox.Instance.Show("Command #1"); + } + + public override bool IsEnabled(TVContext context) { + return context.Nodes.Length > 1; + } + } + + [ExportMenuItem(Header = "Command #2", Group = Constants.GROUP_TREEVIEW, Order = 10)] + sealed class TVCommand2 : TVCtxMenuCommand { + public override void Execute(TVContext context) { + dnSpy.Shared.App.MsgBox.Instance.Show("Command #2"); + } + + public override bool IsVisible(TVContext context) { + return context.Nodes.Length > 0; + } + } + + [ExportMenuItem(Header = "Command #3", Group = Constants.GROUP_TREEVIEW, Order = 20)] + sealed class TVCommand3 : TVCtxMenuCommand { + public override void Execute(TVContext context) { + int secretNum = new Random().Next() % 10; + dnSpy.Shared.App.MsgBox.Instance.Ask("Number", null, "Guess a number", null, s => { + int num; + if (string.IsNullOrWhiteSpace(s)) + return "Enter a number"; + if (!int.TryParse(s, out num)) + return "Not an integer"; + if (num == 42) + return "Nope!"; + if (num != secretNum) + return "WRONG!!!"; + return string.Empty; + }); + } + } + + [ExportMenuItem(Header = "Command #4", Group = Constants.GROUP_TREEVIEW, Order = 30)] + sealed class TVCommand4 : TVCtxMenuCommand { + public override void Execute(TVContext context) { + dnSpy.Shared.App.MsgBox.Instance.Show("Command #4"); + } + + public override bool IsEnabled(TVContext context) { + return context.Nodes.Length == 1 && + context.Nodes[0] is IModuleFileNode; + } + } + + [ExportMenuItem(Group = Constants.GROUP_TREEVIEW, Order = 40)] + sealed class TVCommand5 : TVCtxMenuCommand { + public override void Execute(TVContext context) { + var node = GetTokenNode(context); + if (node != null) { + try { + Clipboard.SetText(string.Format("{0:X8}", node.Reference.MDToken.Raw)); + } + catch (ExternalException) { } + } + } + + IMDTokenNode GetTokenNode(TVContext context) { + if (context.Nodes.Length == 0) + return null; + return context.Nodes[0] as IMDTokenNode; + } + + public override string GetHeader(TVContext context) { + var node = GetTokenNode(context); + if (node == null) + return string.Empty; + return string.Format("Copy token {0:X8}", node.Reference.MDToken.Raw); + } + + public override bool IsVisible(TVContext context) { + return GetTokenNode(context) != null; + } + } + + [ExportMenuItem(Header = "Copy Second Instruction", Group = Constants.GROUP_TREEVIEW, Order = 50)] + sealed class TVCommand6 : TVCtxMenuCommand { + public override void Execute(TVContext context) { + var instr = GetSecondInstruction(context); + if (instr != null) { + try { + Clipboard.SetText(string.Format("Second instruction: {0}", instr)); + } + catch (ExternalException) { } + } + } + + Instruction GetSecondInstruction(TVContext context) { + if (context.Nodes.Length == 0) + return null; + var methNode = context.Nodes[0] as IMethodNode; + if (methNode == null) + return null; + var body = methNode.MethodDef.Body; + if (body == null || body.Instructions.Count < 2) + return null; + return body.Instructions[1]; + } + + public override bool IsEnabled(TVContext context) { + return GetSecondInstruction(context) != null; + } + } +} diff --git a/Plugins/Examples/Example2.Plugin/AssemblyChildNodeTabContent.cs b/Plugins/Examples/Example2.Plugin/AssemblyChildNodeTabContent.cs new file mode 100644 index 000000000..fcf0153da --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/AssemblyChildNodeTabContent.cs @@ -0,0 +1,211 @@ +using System; +using System.Collections.Generic; +using System.Windows; +using System.Windows.Controls; +using dnSpy.Contracts.Files.Tabs; +using dnSpy.Contracts.Files.TreeView; +using dnSpy.Contracts.Settings; +using dnSpy.Shared.MVVM; + +// This file adds custom file tab content when the user clicks on our new AssemblyChildNode tree node. +// This node is created by TreeNodeDataCreator.cs. + +namespace Example2.Plugin { + [ExportFileTabContentFactory] + sealed class AssemblyChildNodeTabContentFactory : IFileTabContentFactory { + // Called to create a new IFileTabContent. If it's our new tree node, create a new IFileTabContent for it + public IFileTabContent Create(IFileTabContentFactoryContext context) { + if (context.Nodes.Length == 1 && context.Nodes[0] is AssemblyChildNode) + return new AssemblyChildNodeTabContent((AssemblyChildNode)context.Nodes[0]); + return null; + } + + //TODO: Use your own guid + static readonly Guid GUID_SerializedContent = new Guid("FC6D2EC8-6FF8-4071-928E-EB07735A6402"); + + public IFileTabContent Deserialize(Guid guid, ISettingsSection section, IFileTabContentFactoryContext context) { + if (guid == GUID_SerializedContent) { + // Serialize() doesn't add anything extra to 'section', but if it did, you'd have to + // get that info here and return null if the serialized data wasn't found. + var node = context.Nodes.Length == 1 ? context.Nodes[0] as AssemblyChildNode : null; + if (node != null) + return new AssemblyChildNodeTabContent(node); + } + return null; + } + + public Guid? Serialize(IFileTabContent content, ISettingsSection section) { + if (content is AssemblyChildNodeTabContent) { + // There's nothing else we need to serialize it, but if there were, use 'section' + // to write the info needed by Deserialize() above. + return GUID_SerializedContent; + } + return null; + } + } + + sealed class AssemblyChildNodeTabContent : IFileTabContent { + // Initialized by the owner + public IFileTab FileTab { get; set; } + + // Returns all nodes used to generate the content + public IEnumerable Nodes { + get { yield return node; } + } + + public string Title { + get { return node.ToString(); } + } + + public object ToolTip { + get { return node.ToString(); } + } + + readonly AssemblyChildNode node; + + public AssemblyChildNodeTabContent(AssemblyChildNode node) { + this.node = node; + } + + // Called when the user opens a new tab + public IFileTabContent Clone() { + return new AssemblyChildNodeTabContent(node); + } + + // Gets called to create the UI context. It can be shared by any IFileTabContent in this tab. + // Eg. there's only one text editor per tab, shared by all IFileTabContents that need a text + // editor. + public IFileTabUIContext CreateUIContext(IFileTabUIContextLocator locator) { + // This custom view object is shared by all nodes of the same type. If we didn't want it + // to be shared, we could use 'node' or 'this' as the key. + var key = node.GetType(); + // var key = node; // uncomment to not share it + + // If the UI object has already been created, use it, else create it. The object is + // stored in a weak reference. + return locator.Get(key, () => new AssemblyChildNodeUIContext()); + } + + public void OnShow(IShowContext ctx) { + // Get the real type, created by CreateUIContext() above. + var uiCtx = (AssemblyChildNodeUIContext)ctx.UIContext; + + // You could initialize some stuff, eg. update its DataContext or whatever + uiCtx.Initialize("some input"); // pretend we need to initialize something + } + + public void OnHide() { + } + + public void OnSelected() { + } + + public void OnUnselected() { + } + } + + sealed class AssemblyChildNodeUIContext : IFileTabUIContext { + // Initialized by the owner + public IFileTab FileTab { get; set; } + + // The element inside UIObject that gets the focus when the tool window should be focused. + // If it's not as easy as calling FocusedElement.Focus() to focus it, you must implement + // dnSpy.Contracts.Controls.IFocusable. + public IInputElement FocusedElement { + get { return content; } + } + + // The element in UIObject that gets the scale transform. null can be returned to disable scaling. + public FrameworkElement ScaleElement { + get { return content; } + } + + // The UI object shown in the tab. Should be a WPF control (eg. UserControl) or a .NET object + // with a DataTemplate. + public object UIObject { + get { return content; } + } + + public void OnHide() { + } + + public void OnShow() { + } + + readonly ContentPresenter content; + readonly AssemblyChildNodeVM vm; + + public AssemblyChildNodeUIContext() { + this.vm = new AssemblyChildNodeVM(); + // A ContentPresenter + DataTemplate is used to show the VM, but you could of course use + // a UserControl. + this.content = new ContentPresenter { + Focusable = true, + Content = this.vm, + }; + } + + sealed class MySerializedData { + public string Value1; + public bool Value2; + + public MySerializedData(string value1, bool value2) { + this.Value1 = value1; + this.Value2 = value2; + } + } + + // Called to create a value that can be used by Deserialize(). It's read from the settings file. + public object CreateSerialized(ISettingsSection section) { + var value1 = section.Attribute("Value1"); + var value2 = section.Attribute("Value2"); + if (value1 == null || value2 == null) + return null; + + return new MySerializedData(value1, value2.Value); + } + + // Saves the value returned by Serialize(). It's saved in the settings file. + public void SaveSerialized(ISettingsSection section, object obj) { + var d = obj as MySerializedData; + if (d == null) + return; + + section.Attribute("Value1", d.Value1); + section.Attribute("Value2", d.Value2); + } + + // Serializes the UI state + public object Serialize() { + // This is where you'd normally serialize the UI state, eg. position etc, but we'll just save random data + return new MySerializedData("Some string", true); + } + + // Deserializes the UI state created by Serialize() + public void Deserialize(object obj) { + var d = obj as MySerializedData; + if (d == null) + return; + + // Here's where you'd restore the UI state, eg position etc. + } + + // Called by AssemblyChildNodeTabContent above to initialize it before it's shown again + public void Initialize(string s) { + // here we could initialize something before it's shown again, eg. initialize the DataContext + } + } + + sealed class AssemblyChildNodeVM : ViewModelBase { + public string SomeMessage { + get { return someMessage; } + set { + if (someMessage != value) { + someMessage = value; + OnPropertyChanged("SomeMessage"); + } + } + } + string someMessage = "Hello World"; + } +} diff --git a/Plugins/Examples/Example2.Plugin/Example2.Plugin.csproj b/Plugins/Examples/Example2.Plugin/Example2.Plugin.csproj new file mode 100644 index 000000000..28b5e847f --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/Example2.Plugin.csproj @@ -0,0 +1,98 @@ + + + + + Debug + AnyCPU + {4613C8A1-28DC-4586-9F9B-D201864CFE1A} + Library + Properties + Example2.Plugin + Example2.Plugin + v4.6 + 512 + + + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + 1685 + + + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + 1685 + + + + + + + + + + + + + + + + + + ToolWindowControl.xaml + + + + + + + + + {fdfc1237-143f-4919-8318-4926901f4639} + dnlib + + + {9b234472-0e22-428c-9345-c8d9ee5e06af} + dnSpy.Contracts + + + {a027546a-cf4b-47f9-bc53-ee1ad424ee41} + dnSpy.Decompiler.Shared + + + {7e7c2cf8-2057-4eaa-9dad-ab3022cf4037} + dnSpy.Shared + + + + + MSBuild:Compile + Designer + + + Designer + MSBuild:Compile + + + + + + + + + + \ No newline at end of file diff --git a/Plugins/Examples/Example2.Plugin/Images/EntryPoint.png b/Plugins/Examples/Example2.Plugin/Images/EntryPoint.png new file mode 100644 index 0000000000000000000000000000000000000000..18ffaabbe84d4a43661019b1ffadae07abbc8207 GIT binary patch literal 221 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`oCO|{#S9F5he4R}c>anMpkTkJ zi(^Pd+|tPhIS(lCxXLb6E)jdr_rOf{h_1{6=1Pz1fPT&R6Q17A$~A(D`u2uaZFVdQ&MBb@0QpQz0ssI2 literal 0 HcmV?d00001 diff --git a/Plugins/Examples/Example2.Plugin/Images/Strings.png b/Plugins/Examples/Example2.Plugin/Images/Strings.png new file mode 100644 index 0000000000000000000000000000000000000000..f7d6811cd9df69c3530411a4140fc4b65aa9f2b6 GIT binary patch literal 154 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`oCO|{#S9F5he4R}c>anMprDVZ zi(^Pd+}TNvTnq{vEVZ}){nx*mx}Mdsy+a_nt0hq|CE&snrAX0T3bP0l+XkK9YQu9 literal 0 HcmV?d00001 diff --git a/Plugins/Examples/Example2.Plugin/Images/TextFile.png b/Plugins/Examples/Example2.Plugin/Images/TextFile.png new file mode 100644 index 0000000000000000000000000000000000000000..23efe7d7b39cab7723737ac8b5743ee684f57cbf GIT binary patch literal 239 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`oCO|{#S9F5M?jcysy3fAP;jBA zi(^Pd+}p{De9VdhuJzI)S^b;BBl>S%E9B}sq*;*5J1M3Ag4{x>P}WI(FI0Rr6jO5J zjZP-q`>$*-J^9RBmD9@w`y>=v7_#58BrsnT2~axk&uO^T?}2gDdoQgh-d&ICn(cIcm}e~S i=ic*OBK3QD9rKQ*ZeedEmfHXw%i!ti=d#Wzp$PzRB2(%B literal 0 HcmV?d00001 diff --git a/Plugins/Examples/Example2.Plugin/NewDnSpyFile.cs b/Plugins/Examples/Example2.Plugin/NewDnSpyFile.cs new file mode 100644 index 000000000..92b30ffc7 --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/NewDnSpyFile.cs @@ -0,0 +1,148 @@ +using System; +using System.ComponentModel.Composition; +using System.IO; +using dnSpy.Contracts.Files; +using dnSpy.Contracts.Files.Tabs.TextEditor; +using dnSpy.Contracts.Files.TreeView; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; +using dnSpy.Shared.Files; +using dnSpy.Shared.Files.TreeView; +using dnSpy.Shared.Highlighting; + +// Adds a new IDnSpyFile that can be loaded into the file treeview. It gets its own IDnSpyFileNode. +// Open a .txt/.xml/.cs/.vb (see supportedExtensions) file to trigger this code. + +namespace Example2.Plugin { + // All root nodes in the file treeview contain a IDnSpyFile instance. They don't need to be + // .NET files or even PE files, they can be any file or even non-file (eg. in-memory data). + sealed class MyDnSpyFile : DnSpyFile { + //TODO: Use your own guid + public static readonly Guid THE_GUID = new Guid("9058B02C-1FE0-4EC4-93D3-A378D4B6FCE1"); + + // We support serialization, so return a non-null value + public override DnSpyFileInfo? SerializedFile { + get { return new DnSpyFileInfo(Filename, THE_GUID); } + } + + // Since we open files from disk, we return a FilenameKey. + // If this gets changed, also update MyDnSpyFileCreator.CreateKey() + public override IDnSpyFilenameKey Key { + get { return new FilenameKey(Filename); } + } + + // Used by MyDnSpyFileNode.Decompile() to show the file in the text editor + public string Text { + get { + if (text != null) + return text; + try { + return text = File.ReadAllText(Filename); + } + catch { + return text = string.Format("Couldn't read the file: {0}", Filename); + } + } + } + string text; + + public static MyDnSpyFile TryCreate(string filename) { + if (!File.Exists(filename)) + return null; + return new MyDnSpyFile(filename); + } + + MyDnSpyFile(string filename) { + this.Filename = filename; + } + } + + // Gets called by the IFileManager instance to create IDnSpyFile instances. If it's a .txt file + // or our MyDnSpyFile.THE_GUID, then create a MyDnSpyFile instance. + [Export(typeof(IDnSpyFileCreator))] + sealed class MyDnSpyFileCreator : IDnSpyFileCreator { + public double Order { + get { return 0; } + } + + public IDnSpyFile Create(IFileManager fileManager, DnSpyFileInfo fileInfo) { + if (fileInfo.Type == MyDnSpyFile.THE_GUID) + return MyDnSpyFile.TryCreate(fileInfo.Name); + // Also check for normal files + if (fileInfo.Type == FileConstants.FILETYPE_FILE && IsSupportedFile(fileInfo.Name)) + return MyDnSpyFile.TryCreate(fileInfo.Name); + return null; + } + + public IDnSpyFilenameKey CreateKey(IFileManager fileManager, DnSpyFileInfo fileInfo) { + if (fileInfo.Type == MyDnSpyFile.THE_GUID) + return new FilenameKey(fileInfo.Name); // Must match the key in MyDnSpyFile.Key + // Also check for normal files + if (fileInfo.Type == FileConstants.FILETYPE_FILE && IsSupportedFile(fileInfo.Name)) + return new FilenameKey(fileInfo.Name); // Must match the key in MyDnSpyFile.Key + return null; + } + + static bool IsSupportedFile(string filename) { + foreach (var ext in supportedExtensions) { + if (filename.EndsWith(ext, StringComparison.OrdinalIgnoreCase)) + return true; + } + return false; + } + static readonly string[] supportedExtensions = new string[] { + ".txt", ".xml", ".cs", ".vb", + }; + } + + // Gets called by dnSpy to create a IDnSpyFileNode + [ExportDnSpyFileNodeCreator] + sealed class MyDnSpyFileNodeCreator : IDnSpyFileNodeCreator { + public IDnSpyFileNode Create(IFileTreeView fileTreeView, IDnSpyFileNode owner, IDnSpyFile file) { + var myFile = file as MyDnSpyFile; + if (myFile != null) + return new MyDnSpyFileNode(myFile); + return null; + } + } + + // Our MyDnSpyFile tree node class. It implements IDecompileSelf to "decompile" itself. You could + // also export a IDecompileNode instance to do it, see TreeNodeDataCreator.cs for an example. + // Or you could create a completely new IFileTabContent for these nodes, see AssemblyChildNodeTabContent.cs + sealed class MyDnSpyFileNode : FileTreeNodeData, IDnSpyFileNode, IDecompileSelf { + //TODO: Use your own guid + public static readonly Guid THE_GUID = new Guid("4174A21D-D746-4658-9A44-DB8235EE5186"); + + public IDnSpyFile DnSpyFile { + get { return file; } + } + readonly MyDnSpyFile file; + + public override Guid Guid { + get { return THE_GUID; } + } + + public override NodePathName NodePathName { + get { return new NodePathName(Guid, file.Filename.ToUpperInvariant()); } + } + + public MyDnSpyFileNode(MyDnSpyFile file) { + this.file = file; + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return new ImageReference(GetType().Assembly, "TextFile"); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.WriteFilename(Path.GetFileName(file.Filename)); + } + + public bool Decompile(IDecompileNodeContext context) { + context.Output.Write(file.Text, TextTokenKind.Text); + return true; + } + } +} diff --git a/Plugins/Examples/Example2.Plugin/Plugin.cs b/Plugins/Examples/Example2.Plugin/Plugin.cs new file mode 100644 index 000000000..8800b20b6 --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/Plugin.cs @@ -0,0 +1,27 @@ +using System.Collections.Generic; +using dnSpy.Contracts.Plugin; + +// Each plugin should export one class implementing IPlugin + +namespace Example2.Plugin { + [ExportPlugin] + sealed class Plugin : IPlugin { + public IEnumerable MergedResourceDictionaries { + get { + yield return "Themes/resourcedict.xaml"; + } + } + + public PluginInfo PluginInfo { + get { + return new PluginInfo { + ShortDescription = "Example2 plugin", + }; + } + } + + public void OnEvent(PluginEvent @event, object obj) { + // We don't care about any events + } + } +} diff --git a/Plugins/Examples/Example2.Plugin/Properties/AssemblyInfo.cs b/Plugins/Examples/Example2.Plugin/Properties/AssemblyInfo.cs new file mode 100644 index 000000000..6f00fadfd --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/Properties/AssemblyInfo.cs @@ -0,0 +1,35 @@ +using System.Reflection; +using System.Runtime.InteropServices; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("Example2.Plugin")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("Example2.Plugin")] +[assembly: AssemblyCopyright("Copyright © 2015")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM components. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("4613c8a1-28dc-4586-9f9b-d201864cfe1a")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +// You can specify all the values or you can default the Build and Revision Numbers +// by using the '*' as shown below: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/Plugins/Examples/Example2.Plugin/README.md b/Plugins/Examples/Example2.Plugin/README.md new file mode 100644 index 000000000..8edd13093 --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/README.md @@ -0,0 +1,8 @@ + +This plugin shows how to do more advanced stuff. It: + +- Adds a tool window (ToolWindowContent.cs) +- Adds new tree nodes (TreeNodeDataCreator.cs) +- Adds custom tab content for the new AssemblyChildNode tree node (AssemblyChildNodeTabContent.cs). ModuleChildNode implements IDecompileSelf to decompile itself. +- Shows tooltips when hovering over custom references added to the text editor (ToolTipContentCreator.cs) +- Adds a new IDnSpyFile instance and IDnSpyFileNode node (NewDnSpyFile.cs). It opens .txt files and shows the output in the text editor. diff --git a/Plugins/Examples/Example2.Plugin/Themes/resourcedict.xaml b/Plugins/Examples/Example2.Plugin/Themes/resourcedict.xaml new file mode 100644 index 000000000..c7f0a7e22 --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/Themes/resourcedict.xaml @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/Plugins/Examples/Example2.Plugin/ToolTipContentCreator.cs b/Plugins/Examples/Example2.Plugin/ToolTipContentCreator.cs new file mode 100644 index 000000000..5a97ad5eb --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/ToolTipContentCreator.cs @@ -0,0 +1,32 @@ +using dnSpy.Contracts.Files.Tabs.TextEditor.ToolTips; +using dnSpy.Decompiler.Shared; + +namespace Example2.Plugin { + // This reference is added to the "decompiled" code by ModuleChildNode.Decompile() + sealed class StringInfoReference { + public string Message { + get { return msg; } + } + readonly string msg; + + public StringInfoReference(string msg) { + this.msg = msg; + } + } + + // Called by dnSpy to create a tooltip when hovering over a reference in the text editor + [ExportToolTipContentCreator(Order = 0)] + sealed class ToolTipContentCreator : IToolTipContentCreator { + public object Create(IToolTipContentCreatorContext context, object @ref) { + // This reference is added to the "decompiled" code by ModuleChildNode.Decompile() + var sref = @ref as StringInfoReference; + if (sref != null) { + var creator = context.Create(); + creator.Output.Write(sref.Message, TextTokenKind.String); + return creator.Create(); + } + + return null; + } + } +} diff --git a/Plugins/Examples/Example2.Plugin/ToolWindowContent.cs b/Plugins/Examples/Example2.Plugin/ToolWindowContent.cs new file mode 100644 index 000000000..9292fafdb --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/ToolWindowContent.cs @@ -0,0 +1,190 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel.Composition; +using System.Windows; +using System.Windows.Input; +using dnSpy.Contracts.Controls; +using dnSpy.Contracts.Menus; +using dnSpy.Contracts.Plugin; +using dnSpy.Contracts.ToolWindows; +using dnSpy.Contracts.ToolWindows.App; +using dnSpy.Shared.Menus; +using dnSpy.Shared.MVVM; + +// Adds a tool window and a command that will show it. The command is added to the View menu and a +// keyboard shortcut is added to the main window. Keyboard shortcut Ctrl+Alt+Z shows the tool window. + +namespace Example2.Plugin { + // Adds the 'OpenToolWindow' command to the main window and sets keyboard shortcut to Ctrl+Alt+Z + [ExportAutoLoaded] + sealed class ToolWindowLoader : IAutoLoaded { + public static readonly RoutedCommand OpenToolWindow = new RoutedCommand("OpenToolWindow", typeof(ToolWindowLoader)); + + [ImportingConstructor] + ToolWindowLoader(IWpfCommandManager wpfCommandManager, IMainToolWindowManager mainToolWindowManager) { + var cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_MAINWINDOW); + cmds.Add(OpenToolWindow, new RelayCommand(a => mainToolWindowManager.Show(ToolWindowContent.THE_GUID))); + cmds.Add(OpenToolWindow, ModifierKeys.Control | ModifierKeys.Alt, Key.Z); + } + } + + // Adds a menu item to the View menu to show the tool window + [ExportMenuItem(OwnerGuid = MenuConstants.APP_MENU_VIEW_GUID, Header = "Plugin Tool Window", InputGestureText = "Ctrl+Alt+Z", Group = MenuConstants.GROUP_APP_MENU_VIEW_WINDOWS, Order = 2000)] + sealed class ViewCommand1 : MenuItemCommand { + ViewCommand1() + : base(ToolWindowLoader.OpenToolWindow) { + } + } + + // Dummy dependency "needed" by MainToolWindowContentCreator + [Export] + sealed class DeppDep { + public void Hello() { + } + } + + // Called by dnSpy to create the tool window + [Export(typeof(IMainToolWindowContentCreator))] + sealed class MainToolWindowContentCreator : IMainToolWindowContentCreator { + // Caches the created tool window + ToolWindowContent ToolWindowContent { + get { return myToolWindowContent ?? (myToolWindowContent = new ToolWindowContent()); } + } + ToolWindowContent myToolWindowContent; + + // Add any deps to the constructor if needed, else remove the constructor + [ImportingConstructor] + MainToolWindowContentCreator(DeppDep deppDep) { + deppDep.Hello(); + } + + // Lets dnSpy know which tool windows it can create and their default locations + public IEnumerable ContentInfos { + get { yield return new ToolWindowContentInfo(ToolWindowContent.THE_GUID, ToolWindowContent.DEFAULT_LOCATION, 0, false); } + } + + // Called by dnSpy. If it's your tool window guid, return the instance. Make sure it's + // cached since it can be called multiple times. + public IToolWindowContent GetOrCreate(Guid guid) { + if (guid == ToolWindowContent.THE_GUID) + return ToolWindowContent; + return null; + } + } + + sealed class ToolWindowContent : IToolWindowContent { + //TODO: Use your own guid + public static readonly Guid THE_GUID = new Guid("18785447-21A8-41DB-B8AD-0F166AEC0D08"); + public const AppToolWindowLocation DEFAULT_LOCATION = AppToolWindowLocation.DefaultHorizontal; + + public Guid Guid { + get { return THE_GUID; } + } + + public string Title { + get { return "Plugin Example"; } + } + + public object ToolTip { + get { return null; } + } + + // This is the object shown in the UI. Return a WPF object or a .NET object with a DataTemplate + public object UIObject { + get { return toolWindowControl; } + } + + // The element inside UIObject that gets the focus when the tool window should be focused. + // If it's not as easy as calling FocusedElement.Focus() to focus it, you must implement + // dnSpy.Contracts.Controls.IFocusable. + public IInputElement FocusedElement { + get { return toolWindowControl.option1TextBox; } + } + + // The element that gets scaled when the user zooms in or out. Return null if zooming isn't + // possible + public FrameworkElement ScaleElement { + get { return toolWindowControl; } + } + + readonly ToolWindowControl toolWindowControl; + readonly ToolWindowVM toolWindowVM; + + public ToolWindowContent() { + this.toolWindowControl = new ToolWindowControl(); + this.toolWindowVM = new ToolWindowVM(); + this.toolWindowControl.DataContext = this.toolWindowVM; + } + + // Gets notified when the content gets hidden, visible, etc. Can be used to tell the view + // model to stop doing stuff when it gets hidden in case it does a lot of work. + public void OnVisibilityChanged(ToolWindowContentVisibilityEvent visEvent) { + switch (visEvent) { + case ToolWindowContentVisibilityEvent.Added: + toolWindowVM.IsEnabled = true; + break; + + case ToolWindowContentVisibilityEvent.Removed: + toolWindowVM.IsEnabled = false; + break; + + case ToolWindowContentVisibilityEvent.Visible: + toolWindowVM.IsVisible = true; + break; + + case ToolWindowContentVisibilityEvent.Hidden: + toolWindowVM.IsVisible = false; + break; + } + } + } + + sealed class ToolWindowVM : ViewModelBase { + public string StringOption1 { + get { return stringOption1; } + set { + if (stringOption1 != value) { + stringOption1 = value; + OnPropertyChanged("StringOption1"); + } + } + } + string stringOption1 = string.Empty; + + public string StringOption2 { + get { return stringOption2; } + set { + if (stringOption2 != value) { + stringOption2 = value; + OnPropertyChanged("StringOption2"); + } + } + } + string stringOption2 = string.Empty; + + public string StringOption3 { + get { return stringOption3; } + set { + if (stringOption3 != value) { + stringOption3 = value; + OnPropertyChanged("StringOption3"); + } + } + } + string stringOption3 = string.Empty; + + public string StringOption4 { + get { return stringOption4; } + set { + if (stringOption4 != value) { + stringOption4 = value; + OnPropertyChanged("StringOption4"); + } + } + } + string stringOption4 = string.Empty; + + public bool IsEnabled { get; set; } + public bool IsVisible { get; set; } + } +} diff --git a/Plugins/Examples/Example2.Plugin/ToolWindowControl.xaml b/Plugins/Examples/Example2.Plugin/ToolWindowControl.xaml new file mode 100644 index 000000000..b756bb29a --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/ToolWindowControl.xaml @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + diff --git a/Plugins/Examples/Example2.Plugin/ToolWindowControl.xaml.cs b/Plugins/Examples/Example2.Plugin/ToolWindowControl.xaml.cs new file mode 100644 index 000000000..8c8bf02a3 --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/ToolWindowControl.xaml.cs @@ -0,0 +1,9 @@ +using System.Windows.Controls; + +namespace Example2.Plugin { + public partial class ToolWindowControl : UserControl { + public ToolWindowControl() { + InitializeComponent(); + } + } +} diff --git a/Plugins/Examples/Example2.Plugin/TreeNodeDataCreator.cs b/Plugins/Examples/Example2.Plugin/TreeNodeDataCreator.cs new file mode 100644 index 000000000..b3652dcaf --- /dev/null +++ b/Plugins/Examples/Example2.Plugin/TreeNodeDataCreator.cs @@ -0,0 +1,266 @@ +using System; +using System.Collections.Generic; +using System.Threading; +using dnSpy.Contracts.Files.Tabs.TextEditor; +using dnSpy.Contracts.Files.TreeView; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.TreeView; +using dnSpy.Decompiler.Shared; +using dnSpy.Shared.Decompiler; +using dnSpy.Shared.Files.TreeView; + +// This file contains classes that create new child nodes of IAssemblyFileNode and IModuleFileNode + +namespace Example2.Plugin { + // This class adds a new child node to all assembly nodes + [ExportTreeNodeDataCreator(Guid = FileTVConstants.ASSEMBLY_NODE_GUID)] + sealed class AssemblyTreeNodeDataCreator : ITreeNodeDataCreator { + public IEnumerable Create(TreeNodeDataCreatorContext context) { + yield return new AssemblyChildNode(); + } + } + + // This class adds a new child node to all module nodes + [ExportTreeNodeDataCreator(Guid = FileTVConstants.MODULE_NODE_GUID)] + sealed class ModuleTreeNodeDataCreator : ITreeNodeDataCreator { + public IEnumerable Create(TreeNodeDataCreatorContext context) { + yield return new ModuleChildNode(); + } + } + + sealed class AssemblyChildNode : FileTreeNodeData { // All file tree nodes should implement IFileTreeNodeData or derive from FileTreeNodeData + //TODO: Use your own guid + public static readonly Guid THE_GUID = new Guid("6CF91674-16CE-44EA-B9E8-80B68C327D30"); + + public override Guid Guid { + get { return THE_GUID; } + } + + public override NodePathName NodePathName { + // If there could be more instances of this class with the same parent, add a second + // argument to the NodePathName constructor, eg. an index or some other unique string. + // Eg. IMethodNode uses the name of the method. + get { return new NodePathName(Guid); } + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + // The image must be in an Images folder (in the resources) and have a .png extension + return new ImageReference(GetType().Assembly, "EntryPoint"); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write("Assembly Child", TextTokenKind.Text); + } + + // If you don't want the node to be appended to the children, override this + public override ITreeNodeGroup TreeNodeGroup { + get { return TreeNodeGroupImpl.Instance; } + } + + sealed class TreeNodeGroupImpl : ITreeNodeGroup { + public static readonly TreeNodeGroupImpl Instance = new TreeNodeGroupImpl(1); + + public TreeNodeGroupImpl(double order) { + this.order = order; + } + + public double Order { + get { return order; } + set { order = value; } + } + double order; + + public int Compare(ITreeNodeData x, ITreeNodeData y) { + if (x == y) + return 0; + var a = x as AssemblyChildNode; + var b = y as AssemblyChildNode; + if (a == null) return -1; + if (b == null) return 1; + // More checks can be added here... + return 0; + } + } + } + + // This class can decompile its own output and implements IDecompileSelf + sealed class ModuleChildNode : FileTreeNodeData, IDecompileSelf { // All file tree nodes should implement IFileTreeNodeData or derive from FileTreeNodeData + //TODO: Use your own guid + public static readonly Guid THE_GUID = new Guid("C8892F6C-6A49-4537-AAA0-D0DEF1E87277"); + + public override Guid Guid { + get { return THE_GUID; } + } + + public override NodePathName NodePathName { + // If there could be more instances of this class with the same parent, add a second + // argument to the NodePathName constructor, eg. an index or some other unique string. + // Eg. IMethodNode uses the name of the method. + get { return new NodePathName(Guid); } + } + + // Initialize() is called after the constructor has been called, and after the TreeNode prop + // has been initialized + public override void Initialize() { + // Set LazyLoading if creating the children could take a while + TreeNode.LazyLoading = true; + } + + // If TreeNode.LazyLoading is false, CreateChildren() is called after Initialize(), else it's + // called when this node gets expanded. + public override IEnumerable CreateChildren() { + // Add some children in random order. They will be sorted because SomeMessageNode + // overrides the TreeNodeGroup prop. + yield return new SomeMessageNode("ZZZZZZZZZZZZZ"); + yield return new SomeMessageNode("AAAAaaaaaAAAAAAA"); + yield return new SomeMessageNode("SAY"); + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + // The image must be in an Images folder (in the resources) and have a .png extension + return new ImageReference(GetType().Assembly, "Strings"); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write("Module Child", TextTokenKind.Text); + } + + // Gets called by dnSpy if there's only one node to decompile. This method gets called in a + // worker thread. The output is also cached unless you call AvalonEditTextOutput.DontCacheOutput(). + public bool Decompile(IDecompileNodeContext context) { + // Pretend we actually do something... + Thread.Sleep(2000); + + // If you don't want the output to be cached, call DontCacheOutput() + bool cacheOutput = true; + if (!cacheOutput) { + var avOutput = context.Output as AvalonEditTextOutput; + if (avOutput != null) + avOutput.DontCacheOutput(); + } + + // Create the output and a few references that other code in this plugin will use, eg. + // to show a tooltip when hovering over the reference. + context.HighlightingExtension = ".cs"; + context.Language.WriteCommentLine(context.Output, "Initialize it to the secret key"); + context.Output.WriteReference("int", new StringInfoReference("This is a reference added by the code"), TextTokenKind.Keyword); + context.Output.WriteSpace(); + context.Output.WriteReference("secret", new StringInfoReference("The real secret is actually 42 not 1234"), TextTokenKind.Local); + context.Output.WriteSpace(); + context.Output.Write("=", TextTokenKind.Operator); + context.Output.WriteSpace(); + context.Output.Write("1234", TextTokenKind.Number); + context.Output.Write(";", TextTokenKind.Operator); + context.Output.WriteLine(); + + // We decompiled ourselves so return true + return true; + } + + // If you don't want the node to be appended to the children, override this + public override ITreeNodeGroup TreeNodeGroup { + get { return TreeNodeGroupImpl.Instance; } + } + + sealed class TreeNodeGroupImpl : ITreeNodeGroup { + // Make sure the order is unique. 0 is already used by the PE node, so use 1 + public static readonly TreeNodeGroupImpl Instance = new TreeNodeGroupImpl(1); + + public TreeNodeGroupImpl(double order) { + this.order = order; + } + + public double Order { + get { return order; } + set { order = value; } + } + double order; + + public int Compare(ITreeNodeData x, ITreeNodeData y) { + if (x == y) + return 0; + var a = x as ModuleChildNode; + var b = y as ModuleChildNode; + if (a == null) return -1; + if (b == null) return 1; + // More checks can be added here... + return 0; + } + } + } + + sealed class SomeMessageNode : FileTreeNodeData { + //TODO: Use your own guid + public static readonly Guid THE_GUID = new Guid("1751CD40-68CE-4F8A-84AF-99371B6FD843"); + + public string Message { + get { return msg; } + } + readonly string msg; + + public SomeMessageNode(string msg) { + this.msg = msg; + } + + public override Guid Guid { + get { return THE_GUID; } + } + + public override NodePathName NodePathName { + get { return new NodePathName(THE_GUID, msg); } + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return new ImageReference(GetType().Assembly, "Strings"); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(msg, TextTokenKind.Comment); + } + + public override ITreeNodeGroup TreeNodeGroup { + get { return TreeNodeGroupImpl.Instance; } + } + + sealed class TreeNodeGroupImpl : ITreeNodeGroup { + public static readonly TreeNodeGroupImpl Instance = new TreeNodeGroupImpl(0); + + public TreeNodeGroupImpl(double order) { + this.order = order; + } + + public double Order { + get { return order; } + set { order = value; } + } + double order; + + public int Compare(ITreeNodeData x, ITreeNodeData y) { + if (x == y) + return 0; + var a = x as SomeMessageNode; + var b = y as SomeMessageNode; + if (a == null) return -1; + if (b == null) return 1; + return StringComparer.OrdinalIgnoreCase.Compare(a.msg, b.msg); + } + } + } + + // SomeMessageNode doesn't implement IDecompileSelf, so we add a "decompiler" that can "decompile" + // those nodes. + [ExportDecompileNode] + sealed class SomeMessageNodeDecompiler : IDecompileNode { + public bool Decompile(IDecompileNodeContext context, IFileTreeNodeData node) { + var msgNode = node as SomeMessageNode; + if (msgNode == null) + return false; + + context.Language.WriteCommentLine(context.Output, "The secret message has been decrypted."); + context.Language.WriteCommentLine(context.Output, string.Format("The message is: {0}", msgNode.Message)); + return true; + } + } +} diff --git a/Plugins/ILSpy.Decompiler/ICSharpCode.Decompiler b/Plugins/ILSpy.Decompiler/ICSharpCode.Decompiler new file mode 160000 index 000000000..e0adc3266 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/ICSharpCode.Decompiler @@ -0,0 +1 @@ +Subproject commit e0adc32662935c90ad494d499033c4c781029da5 diff --git a/Plugins/ILSpy.Decompiler/NRefactory b/Plugins/ILSpy.Decompiler/NRefactory new file mode 160000 index 000000000..a1a3f83bf --- /dev/null +++ b/Plugins/ILSpy.Decompiler/NRefactory @@ -0,0 +1 @@ +Subproject commit a1a3f83bf62dda9c9232e5311e0dedefe4ce11bb diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/AssemblyInfoTransform.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/AssemblyInfoTransform.cs new file mode 100644 index 000000000..83d39b02b --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/AssemblyInfoTransform.cs @@ -0,0 +1,62 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.Diagnostics; +using System.Linq; +using dnlib.DotNet; +using ICSharpCode.Decompiler.Ast.Transforms; +using ICSharpCode.NRefactory.CSharp; + +namespace dnSpy.Languages.ILSpy.CSharp { + sealed class AssemblyInfoTransform : IAstTransform { + public void Run(AstNode compilationUnit) { + foreach (var attrSect in compilationUnit.Descendants.OfType()) { + var attr = attrSect.Descendants.OfType().FirstOrDefault(); + Debug.Assert(attr != null); + if (attr == null) + continue; + var ca = attr.Annotation(); + if (ca == null) + continue; + if (!Compare(ca.AttributeType, systemRuntimeVersioningString, targetFrameworkAttributeString) && + !Compare(ca.AttributeType, systemSecurityString, unverifiableCodeAttributeString)) + continue; + attrSect.Remove(); + } + } + static readonly UTF8String systemRuntimeVersioningString = new UTF8String("System.Runtime.Versioning"); + static readonly UTF8String targetFrameworkAttributeString = new UTF8String("TargetFrameworkAttribute"); + static readonly UTF8String systemSecurityString = new UTF8String("System.Security"); + static readonly UTF8String unverifiableCodeAttributeString = new UTF8String("UnverifiableCodeAttribute"); + + static bool Compare(ITypeDefOrRef type, UTF8String expNs, UTF8String expName) { + if (type == null) + return false; + + var tr = type as TypeRef; + if (tr != null) + return tr.Namespace == expNs && tr.Name == expName; + var td = type as TypeDef; + if (td != null) + return td.Namespace == expNs && td.Name == expName; + + return false; + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/BuilderCache.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/BuilderCache.cs new file mode 100644 index 000000000..5bec46b6a --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/BuilderCache.cs @@ -0,0 +1,76 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Text; +using dnSpy.Contracts.Languages; +using ICSharpCode.Decompiler; +using ICSharpCode.Decompiler.Ast; + +namespace dnSpy.Languages.ILSpy.CSharp { + /// + /// State for one decompiler thread. There should be at most one of these per CPU. This class + /// is not thread safe and must only be accessed by the owner thread. + /// + sealed class AstBuilderState { + public readonly AstBuilder AstBuilder; + + /// + /// instance used by XML doc code. This is always in a random + /// state (random text) and caller must Clear() it before use. + /// + public readonly StringBuilder XmlDoc_StringBuilder; + + public AstBuilderState() { + this.AstBuilder = new AstBuilder(new DecompilerContext(null, true)); + this.XmlDoc_StringBuilder = new StringBuilder(); + } + + /// + /// Called to re-use this instance for another decompilation. Only the fields that need + /// resetting will be reset. + /// + public void Reset() { + AstBuilder.Reset(); + } + } + + /// + /// One instance is created and stored in . It's used by the + /// decompiler threads to get an instance. + /// + sealed class BuilderCache { + readonly ThreadSafeObjectPool astBuilderStatePool; + + public BuilderCache() { + this.astBuilderStatePool = new ThreadSafeObjectPool(Environment.ProcessorCount, createAstBuilderState, resetAstBuilderState); + } + + static readonly Func createAstBuilderState = () => new AstBuilderState(); + static readonly Action resetAstBuilderState = abs => abs.Reset(); + + public AstBuilderState AllocateAstBuilderState() { + return astBuilderStatePool.Allocate(); + } + + public void Free(AstBuilderState state) { + astBuilderStatePool.Free(state); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/BuilderState.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/BuilderState.cs new file mode 100644 index 000000000..98eb374bd --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/BuilderState.cs @@ -0,0 +1,49 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using dnSpy.Contracts.Languages; +using ICSharpCode.Decompiler.Ast; + +namespace dnSpy.Languages.ILSpy.CSharp { + /// + /// Gets the from the pool and returns it when + /// gets called. + /// + struct BuilderState : IDisposable { + public AstBuilder AstBuilder { + get { return State.AstBuilder; } + } + + public readonly AstBuilderState State; + readonly DecompilationContext ctx; + readonly BuilderCache cache; + + public BuilderState(DecompilationContext ctx, BuilderCache cache) { + this.ctx = ctx; + this.cache = cache; + this.State = cache.AllocateAstBuilderState(); + this.State.AstBuilder.Context.CalculateILRanges = ctx.CalculateILRanges; + } + + public void Dispose() { + cache.Free(State); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/CSharpLanguage.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/CSharpLanguage.cs new file mode 100644 index 000000000..62894c1f0 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/CSharpLanguage.cs @@ -0,0 +1,515 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.ComponentModel.Composition; +using System.Diagnostics; +using System.Linq; +using System.Text; +using System.Xml; +using dnlib.DotNet; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; +using dnSpy.Languages.ILSpy.Settings; +using dnSpy.Languages.ILSpy.XmlDoc; +using dnSpy.Shared.Highlighting; +using ICSharpCode.Decompiler; +using ICSharpCode.Decompiler.Ast; +using ICSharpCode.Decompiler.Ast.Transforms; +using ICSharpCode.NRefactory.CSharp; + +namespace dnSpy.Languages.ILSpy.CSharp { + sealed class LanguageProvider : ILanguageProvider { + readonly LanguageSettingsManager languageSettingsManager; + + // Keep the default ctor. It's used by dnSpy.Console.exe + public LanguageProvider() + : this(LanguageSettingsManager.__Instance_DONT_USE) { + } + + public LanguageProvider(LanguageSettingsManager languageSettingsManager) { + Debug.Assert(languageSettingsManager != null); + if (languageSettingsManager == null) + throw new ArgumentNullException(); + this.languageSettingsManager = languageSettingsManager; + } + + public IEnumerable Languages { + get { + yield return new CSharpLanguage(languageSettingsManager.LanguageDecompilerSettings, LanguageConstants.CSHARP_ILSPY_ORDERUI); +#if DEBUG + foreach (var l in CSharpLanguage.GetDebugLanguages(languageSettingsManager.LanguageDecompilerSettings)) + yield return l; +#endif + } + } + } + + [Export(typeof(ILanguageCreator))] + sealed class MyLanguageCreator : ILanguageCreator { + readonly LanguageSettingsManager languageSettingsManager; + + [ImportingConstructor] + MyLanguageCreator(LanguageSettingsManager languageSettingsManager) { + this.languageSettingsManager = languageSettingsManager; + } + + public IEnumerable Create() { + return new LanguageProvider(languageSettingsManager).Languages; + } + } + + /// + /// Decompiler logic for C#. + /// + sealed class CSharpLanguage : Language { + string uniqueNameUI = "C#"; + Guid uniqueGuid = LanguageConstants.LANGUAGE_CSHARP_ILSPY; + bool showAllMembers = false; + Predicate transformAbortCondition = null; + + public override IDecompilerSettings Settings { + get { return langSettings; } + } + readonly LanguageDecompilerSettings langSettings; + + public CSharpLanguage(LanguageDecompilerSettings langSettings, double orderUI) { + this.langSettings = langSettings; + this.orderUI = orderUI; + } + +#if DEBUG + internal static IEnumerable GetDebugLanguages(LanguageDecompilerSettings langSettings) { + DecompilerContext context = new DecompilerContext(new ModuleDefUser("dummy")); + string lastTransformName = "no transforms"; + double orderUI = LanguageConstants.CSHARP_ILSPY_DEBUG_ORDERUI; + uint id = 0xBF67AF3F; + foreach (Type _transformType in TransformationPipeline.CreatePipeline(context).Select(v => v.GetType()).Distinct()) { + Type transformType = _transformType; // copy for lambda + yield return new CSharpLanguage(langSettings, orderUI++) { + transformAbortCondition = v => transformType.IsInstanceOfType(v), + uniqueNameUI = "C# - " + lastTransformName, + uniqueGuid = new Guid(string.Format("203F702E-7E87-4F01-84CD-B0E8{0:X8}", id++)), + showAllMembers = true + }; + lastTransformName = "after " + transformType.Name; + } + yield return new CSharpLanguage(langSettings, orderUI++) { + uniqueNameUI = "C# - " + lastTransformName, + uniqueGuid = new Guid(string.Format("203F702E-7E87-4F01-84CD-B0E8{0:X8}", id++)), + showAllMembers = true + }; + } +#endif + + public override string GenericNameUI { + get { return LanguageConstants.GENERIC_NAMEUI_CSHARP; } + } + + public override string UniqueNameUI { + get { return uniqueNameUI; } + } + + public override double OrderUI { + get { return orderUI; } + } + readonly double orderUI; + + public override Guid GenericGuid { + get { return LanguageConstants.LANGUAGE_CSHARP; } + } + + public override Guid UniqueGuid { + get { return uniqueGuid; } + } + + public override string FileExtension { + get { return ".cs"; } + } + + public override string ProjectFileExtension { + get { return ".csproj"; } + } + + public override void Decompile(MethodDef method, ITextOutput output, DecompilationContext ctx) { + WriteCommentLineDeclaringType(output, method); + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: method.DeclaringType, isSingleMember: true); + try { + if (method.IsConstructor && !method.IsStatic && !method.DeclaringType.IsValueType) { + // also fields and other ctors so that the field initializers can be shown as such + AddFieldsAndCtors(state.AstBuilder, method.DeclaringType, method.IsStatic); + RunTransformsAndGenerateCode(ref state, output, ctx, new SelectCtorTransform(method)); + } + else { + state.AstBuilder.AddMethod(method); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + } + finally { + state.Dispose(); + } + } + + class SelectCtorTransform : IAstTransform { + readonly MethodDef ctorDef; + + public SelectCtorTransform(MethodDef ctorDef) { + this.ctorDef = ctorDef; + } + + public void Run(AstNode compilationUnit) { + ConstructorDeclaration ctorDecl = null; + foreach (var node in compilationUnit.Children) { + ConstructorDeclaration ctor = node as ConstructorDeclaration; + if (ctor != null) { + if (ctor.Annotation() == ctorDef) { + ctorDecl = ctor; + } + else { + // remove other ctors + ctor.Remove(); + } + } + // Remove any fields without initializers + FieldDeclaration fd = node as FieldDeclaration; + if (fd != null && fd.Variables.All(v => v.Initializer.IsNull)) + fd.Remove(); + } + if (ctorDecl.Initializer.ConstructorInitializerType == ConstructorInitializerType.This) { + // remove all fields + foreach (var node in compilationUnit.Children) + if (node is FieldDeclaration) + node.Remove(); + } + } + } + + public override void Decompile(PropertyDef property, ITextOutput output, DecompilationContext ctx) { + WriteCommentLineDeclaringType(output, property); + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: property.DeclaringType, isSingleMember: true); + try { + state.AstBuilder.AddProperty(property); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + + public override void Decompile(FieldDef field, ITextOutput output, DecompilationContext ctx) { + WriteCommentLineDeclaringType(output, field); + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: field.DeclaringType, isSingleMember: true); + try { + if (field.IsLiteral) { + state.AstBuilder.AddField(field); + } + else { + // also decompile ctors so that the field initializer can be shown + AddFieldsAndCtors(state.AstBuilder, field.DeclaringType, field.IsStatic); + } + RunTransformsAndGenerateCode(ref state, output, ctx, new SelectFieldTransform(field)); + } + finally { + state.Dispose(); + } + } + + /// + /// Removes all top-level members except for the specified fields. + /// + sealed class SelectFieldTransform : IAstTransform { + readonly FieldDef field; + + public SelectFieldTransform(FieldDef field) { + this.field = field; + } + + public void Run(AstNode compilationUnit) { + foreach (var child in compilationUnit.Children) { + if (child is EntityDeclaration) { + if (child.Annotation() != field) + child.Remove(); + } + } + } + } + + void AddFieldsAndCtors(AstBuilder codeDomBuilder, TypeDef declaringType, bool isStatic) { + foreach (var field in declaringType.Fields) { + if (field.IsStatic == isStatic) + codeDomBuilder.AddField(field); + } + foreach (var ctor in declaringType.Methods) { + if (ctor.IsConstructor && ctor.IsStatic == isStatic) + codeDomBuilder.AddMethod(ctor); + } + } + + public override void Decompile(EventDef ev, ITextOutput output, DecompilationContext ctx) { + WriteCommentLineDeclaringType(output, ev); + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: ev.DeclaringType, isSingleMember: true); + try { + state.AstBuilder.AddEvent(ev); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + + public override void Decompile(TypeDef type, ITextOutput output, DecompilationContext ctx) { + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: type); + try { + state.AstBuilder.AddType(type); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + + void RunTransformsAndGenerateCode(ref BuilderState state, ITextOutput output, DecompilationContext ctx, IAstTransform additionalTransform = null) { + var astBuilder = state.AstBuilder; + astBuilder.RunTransformations(transformAbortCondition); + if (additionalTransform != null) { + additionalTransform.Run(astBuilder.SyntaxTree); + } + AddXmlDocumentation(ref state, langSettings.Settings, astBuilder); + astBuilder.GenerateCode(output); + } + + internal static void AddXmlDocumentation(ref BuilderState state, DecompilerSettings settings, AstBuilder astBuilder) { + if (settings.ShowXmlDocumentation) { + try { + new AddXmlDocTransform(state.State.XmlDoc_StringBuilder).Run(astBuilder.SyntaxTree); + } + catch (XmlException ex) { + string[] msg = (" Exception while reading XmlDoc: " + ex.ToString()).Split(new[] { '\r', '\n' }, StringSplitOptions.RemoveEmptyEntries); + var insertionPoint = astBuilder.SyntaxTree.FirstChild; + for (int i = 0; i < msg.Length; i++) + astBuilder.SyntaxTree.InsertChildBefore(insertionPoint, new Comment(msg[i], CommentType.Documentation), Roles.Comment); + } + } + } + + public override void Decompile(AssemblyDef asm, ITextOutput output, DecompilationContext ctx) { + WriteAssembly(asm, output, ctx); + + using (ctx.DisableAssemblyLoad()) { + var state = CreateAstBuilder(ctx, langSettings.Settings, currentModule: asm.ManifestModule); + try { + state.AstBuilder.AddAssembly(asm.ManifestModule, true, true, false); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + } + + public override void Decompile(ModuleDef mod, ITextOutput output, DecompilationContext ctx) { + WriteModule(mod, output, ctx); + + using (ctx.DisableAssemblyLoad()) { + var state = CreateAstBuilder(ctx, langSettings.Settings, currentModule: mod); + try { + state.AstBuilder.AddAssembly(mod, true, false, true); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + } + + BuilderState CreateAstBuilder(DecompilationContext ctx, DecompilerSettings settings, ModuleDef currentModule = null, TypeDef currentType = null, bool isSingleMember = false) { + if (currentModule == null) + currentModule = currentType.Module; + if (isSingleMember) { + settings = settings.Clone(); + settings.UsingDeclarations = false; + } + var cache = ctx.GetOrCreate(); + var state = new BuilderState(ctx, cache); + state.AstBuilder.Context.CurrentModule = currentModule; + state.AstBuilder.Context.CancellationToken = ctx.CancellationToken; + state.AstBuilder.Context.CurrentType = currentType; + state.AstBuilder.Context.Settings = settings; + return state; + } + + protected override void TypeToString(ITextOutput output, ITypeDefOrRef type, bool includeNamespace, IHasCustomAttribute typeAttributes = null) { + ConvertTypeOptions options = ConvertTypeOptions.IncludeTypeParameterDefinitions; + if (includeNamespace) + options |= ConvertTypeOptions.IncludeNamespace; + + TypeToString(output, options, type, typeAttributes); + } + + bool WriteRefIfByRef(ITextOutput output, TypeSig typeSig, ParamDef pd) { + if (typeSig.RemovePinnedAndModifiers() is ByRefSig) { + if (pd != null && (!pd.IsIn && pd.IsOut)) { + output.Write("out", TextTokenKind.Keyword); + output.WriteSpace(); + } + else { + output.Write("ref", TextTokenKind.Keyword); + output.WriteSpace(); + } + return true; + } + return false; + } + + void TypeToString(ITextOutput output, ConvertTypeOptions options, ITypeDefOrRef type, IHasCustomAttribute typeAttributes = null) { + if (type == null) + return; + AstType astType = AstBuilder.ConvertType(type, new StringBuilder(), typeAttributes, options); + + if (WriteRefIfByRef(output, type.TryGetByRefSig(), typeAttributes as ParamDef)) { + if (astType is ComposedType && ((ComposedType)astType).PointerRank > 0) + ((ComposedType)astType).PointerRank--; + } + + var module = type.Module; + if (module == null && type is TypeSpec && ((TypeSpec)type).TypeSig.RemovePinnedAndModifiers() is GenericSig) { + var sig = (GenericSig)((TypeSpec)type).TypeSig.RemovePinnedAndModifiers(); + if (sig.OwnerType != null) + module = sig.OwnerType.Module; + if (module == null && sig.OwnerMethod != null && sig.OwnerMethod.DeclaringType != null) + module = sig.OwnerMethod.DeclaringType.Module; + } + var ctx = new DecompilerContext(type.Module); + astType.AcceptVisitor(new CSharpOutputVisitor(new TextTokenWriter(output, ctx), FormattingOptionsFactory.CreateAllman())); + } + + protected override void FormatPropertyName(ITextOutput output, PropertyDef property, bool? isIndexer) { + if (property == null) + throw new ArgumentNullException("property"); + + if (!isIndexer.HasValue) { + isIndexer = property.IsIndexer(); + } + if (isIndexer.Value) { + var accessor = property.GetMethod ?? property.SetMethod; + if (accessor != null && accessor.HasOverrides) { + var methDecl = accessor.Overrides.First().MethodDeclaration; + var declaringType = methDecl == null ? null : methDecl.DeclaringType; + TypeToString(output, declaringType, includeNamespace: true); + output.Write(".", TextTokenKind.Operator); + } + output.Write("this", TextTokenKind.Keyword); + output.Write("[", TextTokenKind.Operator); + bool addSeparator = false; + foreach (var p in property.PropertySig.GetParams()) { + if (addSeparator) { + output.Write(",", TextTokenKind.Operator); + output.WriteSpace(); + } + else + addSeparator = true; + TypeToString(output, p.ToTypeDefOrRef(), includeNamespace: true); + } + output.Write("]", TextTokenKind.Operator); + } + else + WriteIdentifier(output, property.Name, TextTokenKindUtils.GetTextTokenKind(property)); + } + + static readonly HashSet isKeyword = new HashSet(StringComparer.Ordinal) { + "abstract", "as", "base", "bool", "break", "byte", "case", "catch", + "char", "checked", "class", "const", "continue", "decimal", "default", "delegate", + "do", "double", "else", "enum", "event", "explicit", "extern", "false", + "finally", "fixed", "float", "for", "foreach", "goto", "if", "implicit", + "in", "int", "interface", "internal", "is", "lock", "long", "namespace", + "new", "null", "object", "operator", "out", "override", "params", "private", + "protected", "public", "readonly", "ref", "return", "sbyte", "sealed", "short", + "sizeof", "stackalloc", "static", "string", "struct", "switch", "this", "throw", + "true", "try", "typeof", "uint", "ulong", "unchecked", "unsafe", "ushort", + "using", "virtual", "void", "volatile", "while", + }; + + static void WriteIdentifier(ITextOutput output, string id, TextTokenKind tokenKind) { + if (isKeyword.Contains(id)) + output.Write("@", TextTokenKind.Operator); + output.Write(IdentifierEscaper.Escape(id), tokenKind); + } + + protected override void FormatTypeName(ITextOutput output, TypeDef type) { + if (type == null) + throw new ArgumentNullException("type"); + + TypeToString(output, ConvertTypeOptions.DoNotUsePrimitiveTypeNames | ConvertTypeOptions.IncludeTypeParameterDefinitions | ConvertTypeOptions.DoNotIncludeEnclosingType, type); + } + + public override bool ShowMember(IMemberRef member) { + return showAllMembers || !AstBuilder.MemberIsHidden(member, langSettings.Settings); + } + + public override bool CanDecompile(DecompilationType decompilationType) { + switch (decompilationType) { + case DecompilationType.PartialType: + case DecompilationType.AssemblyInfo: + return true; + } + return base.CanDecompile(decompilationType); + } + + public override void Decompile(DecompilationType decompilationType, object data) { + switch (decompilationType) { + case DecompilationType.PartialType: + DecompilePartial((DecompilePartialType)data); + return; + case DecompilationType.AssemblyInfo: + DecompileAssemblyInfo((DecompileAssemblyInfo)data); + return; + } + base.Decompile(decompilationType, data); + } + + void DecompilePartial(DecompilePartialType info) { + var state = CreateAstBuilder(info.Context, CreateDecompilerSettings(langSettings.Settings, info.UseUsingDeclarations), currentType: info.Type); + try { + state.AstBuilder.AddType(info.Type); + RunTransformsAndGenerateCode(ref state, info.Output, info.Context, new DecompilePartialTransform(info.Type, info.Definitions, info.ShowDefinitions, info.AddPartialKeyword, info.InterfacesToRemove)); + } + finally { + state.Dispose(); + } + } + + internal static DecompilerSettings CreateDecompilerSettings(DecompilerSettings settings, bool useUsingDeclarations) { + var newOne = settings.Clone(); + newOne.UsingDeclarations = useUsingDeclarations; + newOne.FullyQualifyAllTypes = !useUsingDeclarations; + return newOne; + } + + void DecompileAssemblyInfo(DecompileAssemblyInfo info) { + var state = CreateAstBuilder(info.Context, langSettings.Settings, currentModule: info.Module); + try { + state.AstBuilder.AddAssembly(info.Module, true, info.Module.IsManifestModule, true); + RunTransformsAndGenerateCode(ref state, info.Output, info.Context, new AssemblyInfoTransform()); + } + finally { + state.Dispose(); + } + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/DecompilePartialTransform.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/DecompilePartialTransform.cs new file mode 100644 index 000000000..40fd0b98e --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/DecompilePartialTransform.cs @@ -0,0 +1,75 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.Collections.Generic; +using System.Diagnostics; +using System.Linq; +using dnlib.DotNet; +using ICSharpCode.Decompiler.Ast.Transforms; +using ICSharpCode.NRefactory.CSharp; + +namespace dnSpy.Languages.ILSpy.CSharp { + sealed class DecompilePartialTransform : IAstTransform { + readonly TypeDef type; + readonly HashSet definitions; + readonly bool showDefinitions; + readonly bool addPartialKeyword; + readonly HashSet ifacesToRemove; + + public DecompilePartialTransform(TypeDef type, HashSet definitions, bool showDefinitions, bool addPartialKeyword, IEnumerable ifacesToRemove) { + this.type = type; + this.definitions = definitions; + this.showDefinitions = showDefinitions; + this.addPartialKeyword = addPartialKeyword; + this.ifacesToRemove = new HashSet(ifacesToRemove, TypeEqualityComparer.Instance); + } + + public void Run(AstNode compilationUnit) { + foreach (var en in compilationUnit.Descendants.OfType()) { + var def = en.Annotation(); + Debug.Assert(def != null); + if (def == null) + continue; + if (def == type) { + var tdecl = en as TypeDeclaration; + Debug.Assert(tdecl != null); + if (tdecl != null) { + if (addPartialKeyword) + tdecl.Modifiers |= Modifiers.Partial; + foreach (var iface in tdecl.BaseTypes) { + var tdr = iface.Annotation(); + if (tdr != null && ifacesToRemove.Contains(tdr)) + iface.Remove(); + } + } + } + else { + if (showDefinitions) { + if (!definitions.Contains(def)) + en.Remove(); + } + else { + if (definitions.Contains(def)) + en.Remove(); + } + } + } + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/ThreadSafeObjectPool.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/ThreadSafeObjectPool.cs new file mode 100644 index 000000000..3127e2d6d --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/CSharp/ThreadSafeObjectPool.cs @@ -0,0 +1,57 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections.Generic; + +namespace dnSpy.Languages.ILSpy.CSharp { + sealed class ThreadSafeObjectPool where T : class { + readonly List freeObjs; + readonly Func createObject; + readonly Action resetObject; + readonly object lockObj = new object(); + + public ThreadSafeObjectPool(int size, Func createObject, Action resetObject) { + if (size <= 0) + throw new ArgumentException(); + this.freeObjs = new List(size); + this.createObject = createObject; + this.resetObject = resetObject; + } + + public T Allocate() { + lock (lockObj) { + if (freeObjs.Count > 0) { + int i = freeObjs.Count - 1; + var o = freeObjs[i]; + freeObjs.RemoveAt(i); + return o; + } + + return createObject(); + } + } + + public void Free(T obj) { + resetObject(obj); + lock (lockObj) + freeObjs.Add(obj); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/IL/ILLanguage.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/IL/ILLanguage.cs new file mode 100644 index 000000000..7ee8c6856 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/IL/ILLanguage.cs @@ -0,0 +1,289 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.ComponentModel.Composition; +using dnlib.DotNet; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Languages.IL; +using dnSpy.Shared.Languages.XmlDoc; +using ICSharpCode.Decompiler.Disassembler; +using dnSpy.Decompiler.Shared; +using dnSpy.Languages.ILSpy.XmlDoc; +using dnSpy.Languages.ILSpy.Settings; +using System.Diagnostics; +using System.Text; + +namespace dnSpy.Languages.ILSpy.IL { + sealed class LanguageProvider : ILanguageProvider { + readonly LanguageSettingsManager languageSettingsManager; + + // Keep the default ctor. It's used by dnSpy.Console.exe + public LanguageProvider() + : this(LanguageSettingsManager.__Instance_DONT_USE) { + } + + public LanguageProvider(LanguageSettingsManager languageSettingsManager) { + Debug.Assert(languageSettingsManager != null); + if (languageSettingsManager == null) + throw new ArgumentNullException(); + this.languageSettingsManager = languageSettingsManager; + } + + public IEnumerable Languages { + get { yield return new ILLanguage(languageSettingsManager.ILLanguageDecompilerSettings); } + } + } + + [Export(typeof(ILanguageCreator))] + sealed class MyLanguageCreator : ILanguageCreator { + readonly LanguageSettingsManager languageSettingsManager; + + [ImportingConstructor] + MyLanguageCreator(LanguageSettingsManager languageSettingsManager) { + this.languageSettingsManager = languageSettingsManager; + } + + public IEnumerable Create() { + return new LanguageProvider(languageSettingsManager).Languages; + } + } + + /// + /// IL language support. + /// + /// + /// Currently comes in two versions: + /// flat IL (detectControlStructure=false) and structured IL (detectControlStructure=true). + /// + sealed class ILLanguage : Language { + readonly bool detectControlStructure; + + public override IDecompilerSettings Settings { + get { return langSettings; } + } + readonly ILLanguageDecompilerSettings langSettings; + + public ILLanguage(ILLanguageDecompilerSettings langSettings) + : this(langSettings, true) { + } + + public ILLanguage(ILLanguageDecompilerSettings langSettings, bool detectControlStructure) { + this.langSettings = langSettings; + this.detectControlStructure = detectControlStructure; + } + + public override double OrderUI { + get { return LanguageConstants.IL_ILSPY_ORDERUI; } + } + + public override string GenericNameUI { + get { return LanguageConstants.GENERIC_NAMEUI_IL; } + } + + public override string UniqueNameUI { + get { return "IL"; } + } + + public override Guid GenericGuid { + get { return LanguageConstants.LANGUAGE_IL; } + } + + public override Guid UniqueGuid { + get { return LanguageConstants.LANGUAGE_IL_ILSPY; } + } + + public override string FileExtension { + get { return ".il"; } + } + + ReflectionDisassembler CreateReflectionDisassembler(ITextOutput output, DecompilationContext ctx, IMemberDef member) { + return CreateReflectionDisassembler(output, ctx, member.Module); + } + + ReflectionDisassembler CreateReflectionDisassembler(ITextOutput output, DecompilationContext ctx, ModuleDef ownerModule) { + var disOpts = new DisassemblerOptions(ctx.CancellationToken, ownerModule); + if (langSettings.Settings.ShowILComments) + disOpts.GetOpCodeDocumentation = ILLanguageHelper.GetOpCodeDocumentation; + var sb = new StringBuilder(); + if (langSettings.Settings.ShowXmlDocumentation) + disOpts.GetXmlDocComments = a => GetXmlDocComments(a, sb); + disOpts.CreateInstructionBytesReader = m => InstructionBytesReader.Create(m, ctx.IsBodyModified != null && ctx.IsBodyModified(m)); + disOpts.ShowTokenAndRvaComments = langSettings.Settings.ShowTokenAndRvaComments; + disOpts.ShowILBytes = langSettings.Settings.ShowILBytes; + disOpts.SortMembers = langSettings.Settings.SortMembers; + return new ReflectionDisassembler(output, detectControlStructure, disOpts); + } + + static IEnumerable GetXmlDocComments(IMemberRef mr, StringBuilder sb) { + if (mr == null || mr.Module == null) + yield break; + var xmldoc = XmlDocLoader.LoadDocumentation(mr.Module); + if (xmldoc == null) + yield break; + string doc = xmldoc.GetDocumentation(XmlDocKeyProvider.GetKey(mr, sb)); + if (string.IsNullOrEmpty(doc)) + yield break; + + foreach (var info in new XmlDocLine(doc)) { + sb.Clear(); + if (info != null) { + sb.Append(' '); + info.Value.WriteTo(sb); + } + yield return sb.ToString(); + } + } + + public override void Decompile(MethodDef method, ITextOutput output, DecompilationContext ctx) { + var dis = CreateReflectionDisassembler(output, ctx, method); + dis.DisassembleMethod(method); + } + + public override void Decompile(FieldDef field, ITextOutput output, DecompilationContext ctx) { + var dis = CreateReflectionDisassembler(output, ctx, field); + dis.DisassembleField(field); + } + + public override void Decompile(PropertyDef property, ITextOutput output, DecompilationContext ctx) { + ReflectionDisassembler rd = CreateReflectionDisassembler(output, ctx, property); + rd.DisassembleProperty(property); + if (property.GetMethod != null) { + output.WriteLine(); + rd.DisassembleMethod(property.GetMethod); + } + if (property.SetMethod != null) { + output.WriteLine(); + rd.DisassembleMethod(property.SetMethod); + } + foreach (var m in property.OtherMethods) { + output.WriteLine(); + rd.DisassembleMethod(m); + } + } + + public override void Decompile(EventDef ev, ITextOutput output, DecompilationContext ctx) { + ReflectionDisassembler rd = CreateReflectionDisassembler(output, ctx, ev); + rd.DisassembleEvent(ev); + if (ev.AddMethod != null) { + output.WriteLine(); + rd.DisassembleMethod(ev.AddMethod); + } + if (ev.RemoveMethod != null) { + output.WriteLine(); + rd.DisassembleMethod(ev.RemoveMethod); + } + foreach (var m in ev.OtherMethods) { + output.WriteLine(); + rd.DisassembleMethod(m); + } + } + + public override void Decompile(TypeDef type, ITextOutput output, DecompilationContext ctx) { + var dis = CreateReflectionDisassembler(output, ctx, type); + dis.DisassembleType(type); + } + + public override void Decompile(AssemblyDef asm, ITextOutput output, DecompilationContext ctx) { + output.WriteLine("// " + asm.ManifestModule.Location, TextTokenKind.Comment); + PrintEntryPoint(asm.ManifestModule, output); + output.WriteLine(); + + ReflectionDisassembler rd = CreateReflectionDisassembler(output, ctx, asm.ManifestModule); + rd.WriteAssemblyHeader(asm); + } + + public override void Decompile(ModuleDef mod, ITextOutput output, DecompilationContext ctx) { + output.WriteLine("// " + mod.Location, TextTokenKind.Comment); + PrintEntryPoint(mod, output); + output.WriteLine(); + + ReflectionDisassembler rd = CreateReflectionDisassembler(output, ctx, mod); + output.WriteLine(); + rd.WriteModuleHeader(mod); + } + + protected override void TypeToString(ITextOutput output, ITypeDefOrRef t, bool includeNamespace, IHasCustomAttribute attributeProvider = null) { + t.WriteTo(output, includeNamespace ? ILNameSyntax.TypeName : ILNameSyntax.ShortTypeName); + } + + public override void WriteToolTip(ISyntaxHighlightOutput output, IMemberRef member, IHasCustomAttribute typeAttributes) { + if (!(member is ITypeDefOrRef) && ILLanguageUtils.Write(SyntaxHighlightOutputToTextOutput.Create(output), member)) + return; + + base.WriteToolTip(output, member, typeAttributes); + } + } + + [Export(typeof(ISimpleILPrinter))] + sealed class ILLanguageUtils : ISimpleILPrinter { + double ISimpleILPrinter.Order { + get { return -100; } + } + + bool ISimpleILPrinter.Write(ITextOutput output, IMemberRef member) { + return Write(output, member); + } + + void ISimpleILPrinter.Write(ITextOutput output, MethodSig sig) { + output.Write(sig); + } + + void ISimpleILPrinter.Write(ITextOutput output, TypeSig type) { + type.WriteTo(output); + } + + public static bool Write(ITextOutput output, IMemberRef member) { + var method = member as IMethod; + if (method != null && method.IsMethod) { + method.WriteMethodTo(output); + return true; + } + + var field = member as IField; + if (field != null && field.IsField) { + field.WriteFieldTo(output); + return true; + } + + var prop = member as PropertyDef; + if (prop != null) { + var dis = new ReflectionDisassembler(output, false, new DisassemblerOptions(new System.Threading.CancellationToken(), null)); + dis.DisassembleProperty(prop, false); + return true; + } + + var evt = member as EventDef; + if (evt != null) { + var dis = new ReflectionDisassembler(output, false, new DisassemblerOptions(new System.Threading.CancellationToken(), null)); + dis.DisassembleEvent(evt, false); + return true; + } + + var type = member as ITypeDefOrRef; + if (type != null) { + type.WriteTo(output, ILNameSyntax.TypeName); + return true; + } + + return false; + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/ILAst/ILAstLanguage.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/ILAst/ILAstLanguage.cs new file mode 100644 index 000000000..78ab7bc70 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/ILAst/ILAstLanguage.cs @@ -0,0 +1,349 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.ComponentModel.Composition; +using System.Diagnostics; +using System.Linq; +using dnlib.DotNet; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; +using dnSpy.Languages.ILSpy.Settings; +using ICSharpCode.Decompiler; +using ICSharpCode.Decompiler.Disassembler; +using ICSharpCode.Decompiler.ILAst; + +namespace dnSpy.Languages.ILSpy.ILAst { + sealed class LanguageProvider : ILanguageProvider { + readonly LanguageSettingsManager languageSettingsManager; + + // Keep the default ctor. It's used by dnSpy.Console.exe + public LanguageProvider() + : this(LanguageSettingsManager.__Instance_DONT_USE) { + } + + public LanguageProvider(LanguageSettingsManager languageSettingsManager) { + Debug.Assert(languageSettingsManager != null); + if (languageSettingsManager == null) + throw new ArgumentNullException(); + this.languageSettingsManager = languageSettingsManager; + } + + public IEnumerable Languages { + get { +#if DEBUG + foreach (var l in ILAstLanguage.GetDebugLanguages(languageSettingsManager)) + yield return l; +#endif + yield break; + } + } + } + + [Export(typeof(ILanguageCreator))] + sealed class MyLanguageCreator : ILanguageCreator { + readonly LanguageSettingsManager languageSettingsManager; + + [ImportingConstructor] + MyLanguageCreator(LanguageSettingsManager languageSettingsManager) { + this.languageSettingsManager = languageSettingsManager; + } + + public IEnumerable Create() { + return new LanguageProvider(languageSettingsManager).Languages; + } + } + +#if DEBUG + /// + /// Represents the ILAst "language" used for debugging purposes. + /// + sealed class ILAstLanguage : Language { + string uniqueNameUI; + Guid uniqueGuid; + bool inlineVariables = true; + ILAstOptimizationStep? abortBeforeStep; + + public override IDecompilerSettings Settings { + get { return langSettings; } + } + readonly IDecompilerSettings langSettings; + + ILAstLanguage(ILAstLanguageDecompilerSettings langSettings, double orderUI) { + this.langSettings = langSettings; + this.orderUI = orderUI; + } + + public override double OrderUI { + get { return orderUI; } + } + readonly double orderUI; + + public override string GenericNameUI { + get { return "ILAst"; } + } + + public override string UniqueNameUI { + get { return uniqueNameUI; } + } + + public override Guid GenericGuid { + get { return LanguageConstants.LANGUAGE_ILAST_ILSPY; } + } + + public override Guid UniqueGuid { + get { return uniqueGuid; } + } + + public override void Decompile(MethodDef method, ITextOutput output, DecompilationContext ctx) { + WriteCommentBegin(output, true); + output.Write("Method: ", TextTokenKind.Comment); + output.WriteDefinition(IdentifierEscaper.Escape(method.FullName), method, TextTokenKind.Comment, false); + WriteCommentEnd(output, true); + output.WriteLine(); + + if (!method.HasBody) { + return; + } + + StartKeywordBlock(output, ".body", method); + + ILAstBuilder astBuilder = new ILAstBuilder(); + ILBlock ilMethod = new ILBlock(); + DecompilerContext context = new DecompilerContext(method.Module) { CurrentType = method.DeclaringType, CurrentMethod = method }; + ilMethod.Body = astBuilder.Build(method, inlineVariables, context); + + if (abortBeforeStep != null) { + new ILAstOptimizer().Optimize(context, ilMethod, abortBeforeStep.Value); + } + + if (context.CurrentMethodIsAsync) { + output.Write("async", TextTokenKind.Keyword); + output.Write("/", TextTokenKind.Operator); + output.WriteLine("await", TextTokenKind.Keyword); + } + + var allVariables = ilMethod.GetSelfAndChildrenRecursive().Select(e => e.Operand as ILVariable) + .Where(v => v != null && !v.IsParameter).Distinct(); + foreach (ILVariable v in allVariables) { + output.WriteDefinition(IdentifierEscaper.Escape(v.Name), v, v.IsParameter ? TextTokenKind.Parameter : TextTokenKind.Local); + if (v.Type != null) { + output.WriteSpace(); + output.Write(":", TextTokenKind.Operator); + output.WriteSpace(); + if (v.IsPinned) { + output.Write("pinned", TextTokenKind.Keyword); + output.WriteSpace(); + } + v.Type.WriteTo(output, ILNameSyntax.ShortTypeName); + } + if (v.GeneratedByDecompiler) { + output.WriteSpace(); + output.Write("[", TextTokenKind.Operator); + output.Write("generated", TextTokenKind.Keyword); + output.Write("]", TextTokenKind.Operator); + } + output.WriteLine(); + } + + var memberMapping = new MemberMapping(method); + foreach (ILNode node in ilMethod.Body) { + node.WriteTo(output, memberMapping); + if (!node.WritesNewLine) + output.WriteLine(); + } + output.AddDebugSymbols(memberMapping); + EndKeywordBlock(output); + } + + void StartKeywordBlock(ITextOutput output, string keyword, IMemberDef member) { + output.Write(keyword, TextTokenKind.Keyword); + output.WriteSpace(); + output.WriteDefinition(IdentifierEscaper.Escape(member.Name), member, TextTokenKindUtils.GetTextTokenKind(member), false); + output.WriteSpace(); + output.WriteLeftBrace(); + output.WriteLine(); + output.Indent(); + } + + void EndKeywordBlock(ITextOutput output) { + output.Unindent(); + output.WriteRightBrace(); + output.WriteLine(); + } + + public override void Decompile(EventDef ev, ITextOutput output, DecompilationContext ctx) { + StartKeywordBlock(output, ".event", ev); + + if (ev.AddMethod != null) { + StartKeywordBlock(output, ".add", ev.AddMethod); + EndKeywordBlock(output); + } + + if (ev.InvokeMethod != null) { + StartKeywordBlock(output, ".invoke", ev.InvokeMethod); + EndKeywordBlock(output); + } + + if (ev.RemoveMethod != null) { + StartKeywordBlock(output, ".remove", ev.RemoveMethod); + EndKeywordBlock(output); + } + + EndKeywordBlock(output); + } + + public override void Decompile(FieldDef field, ITextOutput output, DecompilationContext ctx) { + output.WriteReference(IdentifierEscaper.Escape(field.FieldType.GetFullName()), field.FieldType.ToTypeDefOrRef(), TextTokenKindUtils.GetTextTokenKind(field.FieldType)); + output.WriteSpace(); + output.WriteDefinition(IdentifierEscaper.Escape(field.Name), field, TextTokenKindUtils.GetTextTokenKind(field), false); + var c = field.Constant; + if (c != null) { + output.WriteSpace(); + output.Write("=", TextTokenKind.Operator); + output.WriteSpace(); + if (c.Value == null) + output.Write("null", TextTokenKind.Keyword); + else { + switch (c.Type) { + case ElementType.Boolean: + if (c.Value is bool) + output.Write((bool)c.Value ? "true" : "false", TextTokenKind.Keyword); + else + goto default; + break; + + case ElementType.Char: + output.Write(string.Format("'{0}'", c.Value), TextTokenKind.Char); + break; + + case ElementType.I1: + case ElementType.U1: + case ElementType.I2: + case ElementType.U2: + case ElementType.I4: + case ElementType.U4: + case ElementType.I8: + case ElementType.U8: + case ElementType.R4: + case ElementType.R8: + case ElementType.I: + case ElementType.U: + output.Write(string.Format("{0}", c.Value), TextTokenKind.Number); + break; + + case ElementType.String: + output.Write(string.Format("{0}", c.Value), TextTokenKind.String); + break; + + default: + output.Write(string.Format("{0}", c.Value), TextTokenKind.Text); + break; + } + } + } + } + + public override void Decompile(PropertyDef property, ITextOutput output, DecompilationContext ctx) { + StartKeywordBlock(output, ".property", property); + + foreach (var getter in property.GetMethods) { + StartKeywordBlock(output, ".get", getter); + EndKeywordBlock(output); + } + + foreach (var setter in property.SetMethods) { + StartKeywordBlock(output, ".set", setter); + EndKeywordBlock(output); + } + + foreach (var other in property.OtherMethods) { + StartKeywordBlock(output, ".other", other); + EndKeywordBlock(output); + } + + EndKeywordBlock(output); + } + + public override void Decompile(TypeDef type, ITextOutput output, DecompilationContext ctx) { + this.WriteCommentLine(output, string.Format("Type: {0}", type.FullName)); + if (type.BaseType != null) { + WriteCommentBegin(output, true); + output.Write("Base type: ", TextTokenKind.Comment); + output.WriteReference(IdentifierEscaper.Escape(type.BaseType.FullName), type.BaseType, TextTokenKind.Comment); + WriteCommentEnd(output, true); + output.WriteLine(); + } + foreach (var nested in type.NestedTypes) { + Decompile(nested, output, ctx); + output.WriteLine(); + } + + foreach (var field in type.Fields) { + Decompile(field, output, ctx); + output.WriteLine(); + } + + foreach (var property in type.Properties) { + Decompile(property, output, ctx); + output.WriteLine(); + } + + foreach (var @event in type.Events) { + Decompile(@event, output, ctx); + output.WriteLine(); + } + + foreach (var method in type.Methods) { + Decompile(method, output, ctx); + output.WriteLine(); + } + } + + internal static IEnumerable GetDebugLanguages(LanguageSettingsManager languageSettingsManager) { + double orderUI = LanguageConstants.ILAST_ILSPY_DEBUG_ORDERUI; + uint id = 0x64A926A5; + yield return new ILAstLanguage(languageSettingsManager.ILAstLanguageDecompilerSettings, orderUI++) { + uniqueNameUI = "ILAst (unoptimized)", + uniqueGuid = new Guid(string.Format("CB470049-6AFB-4BDB-93DC-1BB9{0:X8}", id++)), + inlineVariables = false + }; + string nextName = "ILAst (variable splitting)"; + foreach (ILAstOptimizationStep step in Enum.GetValues(typeof(ILAstOptimizationStep))) { + yield return new ILAstLanguage(languageSettingsManager.ILAstLanguageDecompilerSettings, orderUI++) { + uniqueNameUI = nextName, + uniqueGuid = new Guid(string.Format("CB470049-6AFB-4BDB-93DC-1BB9{0:X8}", id++)), + abortBeforeStep = step + }; + nextName = "ILAst (after " + step + ")"; + } + } + + public override string FileExtension { + get { + return ".il"; + } + } + + protected override void TypeToString(ITextOutput output, ITypeDefOrRef t, bool includeNamespace, IHasCustomAttribute attributeProvider = null) { + t.WriteTo(output, includeNamespace ? ILNameSyntax.TypeName : ILNameSyntax.ShortTypeName); + } + } +#endif +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Plugin.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Plugin.cs new file mode 100644 index 000000000..605362ee4 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Plugin.cs @@ -0,0 +1,47 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.Collections.Generic; +using System.ComponentModel.Composition; +using dnSpy.Contracts.Plugin; +using dnSpy.Languages.ILSpy.Properties; + +namespace dnSpy.Languages.ILSpy { + [ExportPlugin] + sealed class Plugin : IPlugin { + [ImportingConstructor] + Plugin() { + } + + public IEnumerable MergedResourceDictionaries { + get { yield return "Themes/wpf.styles.templates.xaml"; } + } + + public PluginInfo PluginInfo { + get { + return new PluginInfo { + ShortDescription = dnSpy_Languages_ILSpy_Resources.Plugin_ShortDescription, + }; + } + } + + public void OnEvent(PluginEvent @event, object obj) { + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/AssemblyInfo.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/AssemblyInfo.cs new file mode 100644 index 000000000..db330dce5 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/AssemblyInfo.cs @@ -0,0 +1,14 @@ +using System.Reflection; +using System.Resources; +using System.Runtime.InteropServices; + +[assembly: AssemblyTitle("Languages.ILSpy.Plugin")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("Languages.ILSpy.Plugin")] +[assembly: AssemblyCopyright("Copyright 2011-2014 AlphaSierraPapa for the SharpDevelop Team")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] +[assembly: ComVisible(false)] +[assembly: NeutralResourcesLanguage("en")] diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.Designer.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.Designer.cs new file mode 100644 index 000000000..bc0098f67 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.Designer.cs @@ -0,0 +1,396 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace dnSpy.Languages.ILSpy.Properties { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + public class dnSpy_Languages_ILSpy_Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal dnSpy_Languages_ILSpy_Resources() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + public static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("dnSpy.Languages.ILSpy.Properties.dnSpy.Languages.ILSpy.Resources", typeof(dnSpy_Languages_ILSpy_Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + public static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + + /// + /// Looks up a localized string similar to C# / VB. + /// + public static string CSharpDecompilerSettingsTabName { + get { + return ResourceManager.GetString("CSharpDecompilerSettingsTabName", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Events. + /// + public static string DecompilationOrder_Events { + get { + return ResourceManager.GetString("DecompilationOrder_Events", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Fields. + /// + public static string DecompilationOrder_Fields { + get { + return ResourceManager.GetString("DecompilationOrder_Fields", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Methods. + /// + public static string DecompilationOrder_Methods { + get { + return ResourceManager.GetString("DecompilationOrder_Methods", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Nested Types. + /// + public static string DecompilationOrder_NestedTypes { + get { + return ResourceManager.GetString("DecompilationOrder_NestedTypes", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Properties. + /// + public static string DecompilationOrder_Properties { + get { + return ResourceManager.GetString("DecompilationOrder_Properties", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Add using declarations. + /// + public static string DecompilerSettings_AddUsingDeclarations { + get { + return ResourceManager.GetString("DecompilerSettings_AddUsingDeclarations", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Always generate exception variables in catch blocks. + /// + public static string DecompilerSettings_AlwaysGenerateExceptionVariableForCatchBlocks { + get { + return ResourceManager.GetString("DecompilerSettings_AlwaysGenerateExceptionVariableForCatchBlocks", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompilation order. + /// + public static string DecompilerSettings_DecompilationOrder { + get { + return ResourceManager.GetString("DecompilerSettings_DecompilationOrder", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile anonymous methods/lambdas. + /// + public static string DecompilerSettings_DecompileAnonMethods { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileAnonMethods", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile async methods (async/await). + /// + public static string DecompilerSettings_DecompileAsyncMethods { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileAsyncMethods", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile automatic events. + /// + public static string DecompilerSettings_DecompileAutoEvents { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileAutoEvents", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile automatic properties. + /// + public static string DecompilerSettings_DecompileAutoProps { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileAutoProps", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile enumerators (yield return). + /// + public static string DecompilerSettings_DecompileEnumerators { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileEnumerators", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile expression trees. + /// + public static string DecompilerSettings_DecompileExprTrees { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileExprTrees", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile foreach statements. + /// + public static string DecompilerSettings_DecompileForeachStatements { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileForeachStatements", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile lock statements. + /// + public static string DecompilerSettings_DecompileLockStatements { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileLockStatements", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile query expressions. + /// + public static string DecompilerSettings_DecompileQueryExpr { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileQueryExpr", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile switch on string. + /// + public static string DecompilerSettings_DecompileSwitchOnString { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileSwitchOnString", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile using statements. + /// + public static string DecompilerSettings_DecompileUsingStatements { + get { + return ResourceManager.GetString("DecompilerSettings_DecompileUsingStatements", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Add namespaces to all types. + /// + public static string DecompilerSettings_FullyQualifyAllTypes { + get { + return ResourceManager.GetString("DecompilerSettings_FullyQualifyAllTypes", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Add a namespace to types with the same name. + /// + public static string DecompilerSettings_FullyQualifyAmbiguousTypeNames { + get { + return ResourceManager.GetString("DecompilerSettings_FullyQualifyAmbiguousTypeNames", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Use increment and decrement operators. + /// + public static string DecompilerSettings_IntroduceIncrementAndDecrement { + get { + return ResourceManager.GetString("DecompilerSettings_IntroduceIncrementAndDecrement", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Use assignment expressions such as in while ((count = Do()) != 0) ;. + /// + public static string DecompilerSettings_MakeAssignmentExpressions { + get { + return ResourceManager.GetString("DecompilerSettings_MakeAssignmentExpressions", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Max number of array elements to show. + /// + public static string DecompilerSettings_MaxArrayElements { + get { + return ResourceManager.GetString("DecompilerSettings_MaxArrayElements", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Decompile object or collection initializers. + /// + public static string DecompilerSettings_ObjectOrCollectionInitializers { + get { + return ResourceManager.GetString("DecompilerSettings_ObjectOrCollectionInitializers", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Remove empty default constructors. + /// + public static string DecompilerSettings_RemoveEmptyDefaultCtors { + get { + return ResourceManager.GetString("DecompilerSettings_RemoveEmptyDefaultCtors", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Show hidden compiler generated types and methods. + /// + public static string DecompilerSettings_ShowCompilerGeneratedTypes { + get { + return ResourceManager.GetString("DecompilerSettings_ShowCompilerGeneratedTypes", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Show IL opcode comments. + /// + public static string DecompilerSettings_ShowILComments { + get { + return ResourceManager.GetString("DecompilerSettings_ShowILComments", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Show IL instruction bytes. + /// + public static string DecompilerSettings_ShowILInstrBytes { + get { + return ResourceManager.GetString("DecompilerSettings_ShowILInstrBytes", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Show tokens, RVAs and file offsets. + /// + public static string DecompilerSettings_ShowTokensRvasOffsets { + get { + return ResourceManager.GetString("DecompilerSettings_ShowTokensRvasOffsets", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Show XML documentation in decompiled code. + /// + public static string DecompilerSettings_ShowXMLDocComments { + get { + return ResourceManager.GetString("DecompilerSettings_ShowXMLDocComments", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Sort methods, fields, properties, events and types. + /// + public static string DecompilerSettings_SortMethods { + get { + return ResourceManager.GetString("DecompilerSettings_SortMethods", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Place 'System' directives first when sorting usings. + /// + public static string DecompilerSettings_SortSystemFirst { + get { + return ResourceManager.GetString("DecompilerSettings_SortSystemFirst", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Use variable names from debug symbols, if available. + /// + public static string DecompilerSettings_UseLocalNameFromSyms { + get { + return ResourceManager.GetString("DecompilerSettings_UseLocalNameFromSyms", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to IL. + /// + public static string ILDecompilerSettingsTabName { + get { + return ResourceManager.GetString("ILDecompilerSettingsTabName", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to ILSpy decompiler. + /// + public static string Plugin_ShortDescription { + get { + return ResourceManager.GetString("Plugin_ShortDescription", resourceCulture); + } + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.resx b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.resx new file mode 100644 index 000000000..a6b53cd68 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.resx @@ -0,0 +1,231 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + C# / VB + + + Events + + + Fields + + + Methods + + + Nested Types + + + Properties + + + Add using declarations + + + Always generate exception variables in catch blocks + + + Decompilation order + + + Decompile anonymous methods/lambdas + + + Decompile async methods (async/await) + + + Decompile automatic events + + + Decompile automatic properties + + + Decompile enumerators (yield return) + + + Decompile expression trees + + + Decompile foreach statements + + + Decompile lock statements + + + Decompile query expressions + + + Decompile switch on string + + + Decompile using statements + + + Add namespaces to all types + + + Add a namespace to types with the same name + + + Use increment and decrement operators + + + Use assignment expressions such as in while ((count = Do()) != 0) ; + + + Max number of array elements to show + + + Decompile object or collection initializers + + + Remove empty default constructors + + + Show hidden compiler generated types and methods + + + Show IL opcode comments + + + Show IL instruction bytes + + + Show tokens, RVAs and file offsets + + + Show XML documentation in decompiled code + + + Sort methods, fields, properties, events and types + + + Place 'System' directives first when sorting usings + + + Use variable names from debug symbols, if available + + + IL + + + ILSpy decompiler + + \ No newline at end of file diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.ru.resx b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.ru.resx new file mode 100644 index 000000000..3d77f7305 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.ru.resx @@ -0,0 +1,231 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + С# / VB + + + События + + + Поля + + + Методы + + + Вложенные типы + + + Свойства + + + Добавить определения using + + + Всегда создавать переменные исключений в блоках catch + + + Порядок декомпиляции + + + Декомпилировать анонимные методы/лямбды + + + Декомпилировать асинхронные методы (async/await) + + + Декомпилировать автоматические события + + + Декомпилировать автоматические свойства + + + Декомпилировать перечислители (yield return) + + + Декомпилировать деревья выражений + + + Декомпилировать операторы foreach + + + Декомпилировать операторы lock + + + Декомпилировать выражения запросов + + + Декомпилировать switch по строкам + + + Декомпилировать операторы using + + + Добавить пространства имен во все типы + + + Добавить пространство имен в типы с таким же именем + + + Использовать операторы инкремента и декремента + + + Использовать выражения присваивания, такие как в while ((count = Do()) != 0); + + + Максимальное количество отображаемых элементов массива + + + Декомпилировать инициализаторы объекта или коллекции + + + Удалить пустые конструкторы по умолчанию + + + Показать скрытые типы и методы, созданные компилятором + + + Показать комментарии к IL инструкциям + + + Показывать байты инструкций IL + + + Показывать токены, RVA и смещения в файле + + + Показать документацию XML в декомпилированном коде + + + Сортировать методы, поля, свойства, события и типы + + + Поместить директивы 'System' в начало при сортировке + + + Использовать имена переменных из отладочных символов, при наличии + + + IL + + + Декомпилятор ILSpy + + diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.zh-CN.resx b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.zh-CN.resx new file mode 100644 index 000000000..3eab6403e --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Properties/dnSpy.Languages.ILSpy.Resources.zh-CN.resx @@ -0,0 +1,231 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + C# / VB + + + 事件 + + + 字段 + + + 方法 + + + 嵌套类 + + + 属性 + + + 添加using声明 + + + 在catch块中总是生成异常变量 + + + 反编译顺序 + + + 反编译匿名方法/lambda方法 + + + 反编译异步方法 (async/await) + + + 反编译自动生成的事件 + + + 反编译自动生成的属性 + + + 反编译枚举器(yield return) + + + 反编译表达式树(Expression Trees) + + + 反编译foreach语句 + + + 反编译lock语句 + + + 反编译查询表达式 + + + Decompile switch on string + + + 反编译using语句 + + + 将命名空间名添加到所有类型 + + + 将命名空间名添加到具有相同名称的类型 + + + 使用增量和减量运算符 + + + 在流程控制语句中使用赋值表达式(如while ((count = Do()) != 0) ;) + + + 要显示的数组元素最大数量 + + + 反编译对象或集合的初始值设定项 + + + 删除空的默认构造函数 + + + 显示编译器生成的隐藏类型和方法 + + + 显示IL操作码注释 + + + 显示IL指令字节 + + + 显示token,RVA和file offset + + + 在反编译的代码中显示 XML 文档 + + + 排序方法、 字段、 属性、 事件和类型 + + + 在排序using时将System系列置于首位 + + + 如果可用,使用debug symbols声明的变量名称 + + + IL + + + ILSpy 反编译器 + + diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/CSharpDecompilerSettingsTab.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/CSharpDecompilerSettingsTab.cs new file mode 100644 index 000000000..1fddb3490 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/CSharpDecompilerSettingsTab.cs @@ -0,0 +1,220 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.ComponentModel; +using System.Diagnostics; +using System.Linq; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.Settings.Dialog; +using dnSpy.Languages.ILSpy.Properties; +using dnSpy.Shared.MVVM; +using ICSharpCode.Decompiler; + +namespace dnSpy.Languages.ILSpy.Settings { + sealed class CSharpDecompilerSettingsTab : IDecompilerSettingsTab, INotifyPropertyChanged { + readonly DecompilerSettings _global_decompilerSettings; + readonly DecompilerSettings decompilerSettings; + + public event PropertyChangedEventHandler PropertyChanged; + void OnPropertyChanged(string propName) { + if (PropertyChanged != null) + PropertyChanged(this, new PropertyChangedEventArgs(propName)); + } + + public double Order { + get { return LanguageConstants.ORDER_DECOMPILER_SETTINGS_ILSPY_CSHARP; } + } + + public string Name { + get { return dnSpy_Languages_ILSpy_Resources.CSharpDecompilerSettingsTabName; } + } + + public DecompilerSettings Settings { + get { return decompilerSettings; } + } + + public object UIObject { + get { return this; } + } + + public DecompilationObjectVM[] DecompilationObjectsArray { + get { return decompilationObjectVMs2; } + } + readonly DecompilationObjectVM[] decompilationObjectVMs; + readonly DecompilationObjectVM[] decompilationObjectVMs2; + + public DecompilationObjectVM DecompilationObject0 { + get { return decompilationObjectVMs[0]; } + set { SetDecompilationObject(0, value); } + } + + public DecompilationObjectVM DecompilationObject1 { + get { return decompilationObjectVMs[1]; } + set { SetDecompilationObject(1, value); } + } + + public DecompilationObjectVM DecompilationObject2 { + get { return decompilationObjectVMs[2]; } + set { SetDecompilationObject(2, value); } + } + + public DecompilationObjectVM DecompilationObject3 { + get { return decompilationObjectVMs[3]; } + set { SetDecompilationObject(3, value); } + } + + public DecompilationObjectVM DecompilationObject4 { + get { return decompilationObjectVMs[4]; } + set { SetDecompilationObject(4, value); } + } + + void SetDecompilationObject(int index, DecompilationObjectVM newValue) { + Debug.Assert(newValue != null); + if (newValue == null) + throw new ArgumentNullException(); + if (decompilationObjectVMs[index] == newValue) + return; + + int otherIndex = Array.IndexOf(decompilationObjectVMs, newValue); + Debug.Assert(otherIndex >= 0); + if (otherIndex >= 0) { + decompilationObjectVMs[otherIndex] = decompilationObjectVMs[index]; + decompilationObjectVMs[index] = newValue; + + OnPropertyChanged(string.Format("DecompilationObject{0}", otherIndex)); + } + OnPropertyChanged(string.Format("DecompilationObject{0}", index)); + } + + public CSharpDecompilerSettingsTab(DecompilerSettings decompilerSettings) { + this._global_decompilerSettings = decompilerSettings; + this.decompilerSettings = decompilerSettings.Clone(); + + var defObjs = typeof(DecompilationObject).GetEnumValues().Cast().ToArray(); + this.decompilationObjectVMs = new DecompilationObjectVM[defObjs.Length]; + for (int i = 0; i < defObjs.Length; i++) + this.decompilationObjectVMs[i] = new DecompilationObjectVM(defObjs[i], ToString(defObjs[i])); + this.decompilationObjectVMs2 = this.decompilationObjectVMs.ToArray(); + + this.DecompilationObject0 = this.decompilationObjectVMs.First(a => a.Object == decompilerSettings.DecompilationObject0); + this.DecompilationObject1 = this.decompilationObjectVMs.First(a => a.Object == decompilerSettings.DecompilationObject1); + this.DecompilationObject2 = this.decompilationObjectVMs.First(a => a.Object == decompilerSettings.DecompilationObject2); + this.DecompilationObject3 = this.decompilationObjectVMs.First(a => a.Object == decompilerSettings.DecompilationObject3); + this.DecompilationObject4 = this.decompilationObjectVMs.First(a => a.Object == decompilerSettings.DecompilationObject4); + } + + static string ToString(DecompilationObject o) { + switch (o) { + case DecompilationObject.NestedTypes: return dnSpy_Languages_ILSpy_Resources.DecompilationOrder_NestedTypes; + case DecompilationObject.Fields: return dnSpy_Languages_ILSpy_Resources.DecompilationOrder_Fields; + case DecompilationObject.Events: return dnSpy_Languages_ILSpy_Resources.DecompilationOrder_Events; + case DecompilationObject.Properties: return dnSpy_Languages_ILSpy_Resources.DecompilationOrder_Properties; + case DecompilationObject.Methods: return dnSpy_Languages_ILSpy_Resources.DecompilationOrder_Methods; + default: + Debug.Fail("Shouldn't be here"); + return "???"; + } + } + + [Flags] + public enum RefreshFlags { + ShowMember = 0x00000001, + ILAst = 0x00000002, + CSharp = 0x00000004, + VB = 0x00000008, + DecompileAll = ILAst | CSharp | VB, + } + + public void OnClosed(bool saveSettings, IAppRefreshSettings appRefreshSettings) { + if (!saveSettings) + return; + + RefreshFlags flags = 0; + var g = _global_decompilerSettings; + var d = decompilerSettings; + + d.DecompilationObject0 = DecompilationObject0.Object; + d.DecompilationObject1 = DecompilationObject1.Object; + d.DecompilationObject2 = DecompilationObject2.Object; + d.DecompilationObject3 = DecompilationObject3.Object; + d.DecompilationObject4 = DecompilationObject4.Object; + + if (g.AnonymousMethods != d.AnonymousMethods) flags |= RefreshFlags.ILAst | RefreshFlags.ShowMember; + if (g.ExpressionTrees != d.ExpressionTrees) flags |= RefreshFlags.ILAst; + if (g.YieldReturn != d.YieldReturn) flags |= RefreshFlags.ILAst | RefreshFlags.ShowMember; + if (g.AsyncAwait != d.AsyncAwait) flags |= RefreshFlags.ILAst | RefreshFlags.ShowMember; + if (g.AutomaticProperties != d.AutomaticProperties) flags |= RefreshFlags.CSharp | RefreshFlags.ShowMember; + if (g.AutomaticEvents != d.AutomaticEvents) flags |= RefreshFlags.CSharp | RefreshFlags.ShowMember; + if (g.UsingStatement != d.UsingStatement) flags |= RefreshFlags.CSharp; + if (g.ForEachStatement != d.ForEachStatement) flags |= RefreshFlags.CSharp; + if (g.LockStatement != d.LockStatement) flags |= RefreshFlags.CSharp; + if (g.SwitchStatementOnString != d.SwitchStatementOnString) flags |= RefreshFlags.CSharp | RefreshFlags.ShowMember; + if (g.UsingDeclarations != d.UsingDeclarations) flags |= RefreshFlags.CSharp; + if (g.QueryExpressions != d.QueryExpressions) flags |= RefreshFlags.CSharp; + if (g.FullyQualifyAmbiguousTypeNames != d.FullyQualifyAmbiguousTypeNames) flags |= RefreshFlags.CSharp; + if (g.FullyQualifyAllTypes != d.FullyQualifyAllTypes) flags |= RefreshFlags.CSharp; + if (g.UseDebugSymbols != d.UseDebugSymbols) flags |= RefreshFlags.DecompileAll; + if (g.ObjectOrCollectionInitializers != d.ObjectOrCollectionInitializers) flags |= RefreshFlags.ILAst; + if (g.ShowXmlDocumentation != d.ShowXmlDocumentation) flags |= RefreshFlags.DecompileAll; + if (g.RemoveEmptyDefaultConstructors != d.RemoveEmptyDefaultConstructors) flags |= RefreshFlags.CSharp; + if (g.IntroduceIncrementAndDecrement != d.IntroduceIncrementAndDecrement) flags |= RefreshFlags.ILAst; + if (g.MakeAssignmentExpressions != d.MakeAssignmentExpressions) flags |= RefreshFlags.ILAst; + if (g.AlwaysGenerateExceptionVariableForCatchBlocks != d.AlwaysGenerateExceptionVariableForCatchBlocks) flags |= RefreshFlags.ILAst; + if (g.ShowTokenAndRvaComments != d.ShowTokenAndRvaComments) flags |= RefreshFlags.DecompileAll; + if (g.DecompilationObject0 != d.DecompilationObject0) flags |= RefreshFlags.CSharp; + if (g.DecompilationObject1 != d.DecompilationObject1) flags |= RefreshFlags.CSharp; + if (g.DecompilationObject2 != d.DecompilationObject2) flags |= RefreshFlags.CSharp; + if (g.DecompilationObject3 != d.DecompilationObject3) flags |= RefreshFlags.CSharp; + if (g.DecompilationObject4 != d.DecompilationObject4) flags |= RefreshFlags.CSharp; + if (g.SortMembers != d.SortMembers) flags |= RefreshFlags.CSharp; + if (g.ForceShowAllMembers != d.ForceShowAllMembers) flags |= RefreshFlags.CSharp | RefreshFlags.ShowMember; + if (g.SortSystemUsingStatementsFirst != d.SortSystemUsingStatementsFirst) flags |= RefreshFlags.CSharp; + if (g.MaxArrayElements != d.MaxArrayElements) flags |= RefreshFlags.CSharp; + + if ((flags & RefreshFlags.ShowMember) != 0) + appRefreshSettings.Add(AppSettingsConstants.REFRESH_LANGUAGE_SHOWMEMBER); + if ((flags & RefreshFlags.ILAst) != 0) + appRefreshSettings.Add(SettingsConstants.REDECOMPILE_ILAST_ILSPY_CODE); + if ((flags & RefreshFlags.CSharp) != 0) + appRefreshSettings.Add(SettingsConstants.REDECOMPILE_CSHARP_ILSPY_CODE); + if ((flags & RefreshFlags.VB) != 0) + appRefreshSettings.Add(SettingsConstants.REDECOMPILE_VB_ILSPY_CODE); + + decompilerSettings.CopyTo(_global_decompilerSettings); + } + } + + sealed class DecompilationObjectVM : ViewModelBase { + public DecompilationObject Object { + get { return decompilationObject; } + } + readonly DecompilationObject decompilationObject; + + public string Text { + get { return text; } + } + readonly string text; + + public DecompilationObjectVM(DecompilationObject decompilationObject, string text) { + this.decompilationObject = decompilationObject; + this.text = text; + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerAppSettingsModifiedListener.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerAppSettingsModifiedListener.cs new file mode 100644 index 000000000..2b0dff47a --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerAppSettingsModifiedListener.cs @@ -0,0 +1,75 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections.Generic; +using System.ComponentModel.Composition; +using System.Linq; +using dnSpy.Contracts.Files.Tabs; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.Settings.Dialog; + +namespace dnSpy.Languages.ILSpy.Settings { + [ExportAppSettingsModifiedListener(Order = AppSettingsConstants.ORDER_SETTINGS_LISTENER_DECOMPILER)] + sealed class DecompilerAppSettingsModifiedListener : IAppSettingsModifiedListener { + readonly IFileTabManager fileTabManager; + + [ImportingConstructor] + DecompilerAppSettingsModifiedListener(IFileTabManager fileTabManager) { + this.fileTabManager = fileTabManager; + } + + public void OnSettingsModified(IAppRefreshSettings appRefreshSettings) { + bool refreshIL = appRefreshSettings.Has(SettingsConstants.REDISASSEMBLE_IL_ILSPY_CODE); + bool refreshILAst = appRefreshSettings.Has(SettingsConstants.REDECOMPILE_ILAST_ILSPY_CODE); + bool refreshCSharp = appRefreshSettings.Has(SettingsConstants.REDECOMPILE_CSHARP_ILSPY_CODE); + bool refreshVB = appRefreshSettings.Has(SettingsConstants.REDECOMPILE_VB_ILSPY_CODE); + if (refreshILAst) + refreshCSharp = refreshVB = true; + if (refreshCSharp) + refreshVB = true; + + if (refreshIL) + RefreshCode(); +#if DEBUG + if (refreshILAst) + RefreshCode(); +#endif + if (refreshCSharp) + RefreshCode(); + if (refreshVB) + RefreshCode(); + } + + IEnumerable> LanguageTabs { + get { + foreach (var tab in fileTabManager.VisibleFirstTabs) { + var langContent = tab.Content as ILanguageTabContent; + var lang = langContent == null ? null : langContent.Language; + if (lang != null) + yield return Tuple.Create(tab, lang); + } + } + } + + void RefreshCode() { + fileTabManager.Refresh(LanguageTabs.Where(t => t.Item2 is T).Select(a => a.Item1).ToArray()); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerSettingsImpl.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerSettingsImpl.cs new file mode 100644 index 000000000..7f2122a1c --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerSettingsImpl.cs @@ -0,0 +1,115 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.ComponentModel.Composition; +using dnSpy.Contracts.Settings; +using ICSharpCode.Decompiler; + +namespace dnSpy.Languages.ILSpy.Settings { + [Export, PartCreationPolicy(CreationPolicy.Shared)] + sealed class DecompilerSettingsImpl : DecompilerSettings { + static readonly Guid SETTINGS_GUID = new Guid("6745457F-254B-4B7B-90F1-F948F0721C3B"); + + readonly ISettingsManager settingsManager; + + [ImportingConstructor] + DecompilerSettingsImpl(ISettingsManager settingsManager) { + this.settingsManager = settingsManager; + + this.disableSave = true; + var sect = settingsManager.GetOrCreateSection(SETTINGS_GUID); + // Only read those settings that can be changed in the dialog box + this.DecompilationObject0 = sect.Attribute("DecompilationObject0") ?? this.DecompilationObject0; + this.DecompilationObject1 = sect.Attribute("DecompilationObject1") ?? this.DecompilationObject1; + this.DecompilationObject2 = sect.Attribute("DecompilationObject2") ?? this.DecompilationObject2; + this.DecompilationObject3 = sect.Attribute("DecompilationObject3") ?? this.DecompilationObject3; + this.DecompilationObject4 = sect.Attribute("DecompilationObject4") ?? this.DecompilationObject4; + this.AnonymousMethods = sect.Attribute("AnonymousMethods") ?? this.AnonymousMethods; + this.ExpressionTrees = sect.Attribute("ExpressionTrees") ?? this.ExpressionTrees; + this.YieldReturn = sect.Attribute("YieldReturn") ?? this.YieldReturn; + this.AsyncAwait = sect.Attribute("AsyncAwait") ?? this.AsyncAwait; +// this.AutomaticProperties = sect.Attribute("AutomaticProperties") ?? this.AutomaticProperties; +// this.AutomaticEvents = sect.Attribute("AutomaticEvents") ?? this.AutomaticEvents; +// this.UsingStatement = sect.Attribute("UsingStatement") ?? this.UsingStatement; +// this.ForEachStatement = sect.Attribute("ForEachStatement") ?? this.ForEachStatement; +// this.LockStatement = sect.Attribute("LockStatement") ?? this.LockStatement; +// this.SwitchStatementOnString = sect.Attribute("SwitchStatementOnString") ?? this.SwitchStatementOnString; +// this.UsingDeclarations = sect.Attribute("UsingDeclarations") ?? this.UsingDeclarations; + this.QueryExpressions = sect.Attribute("QueryExpressions") ?? this.QueryExpressions; +// this.FullyQualifyAmbiguousTypeNames = sect.Attribute("FullyQualifyAmbiguousTypeNames") ?? this.FullyQualifyAmbiguousTypeNames; +// this.FullyQualifyAllTypes = sect.Attribute("FullyQualifyAllTypes") ?? this.FullyQualifyAllTypes; + this.UseDebugSymbols = sect.Attribute("UseDebugSymbols") ?? this.UseDebugSymbols; +// this.ObjectOrCollectionInitializers = sect.Attribute("ObjectOrCollectionInitializers") ?? this.ObjectOrCollectionInitializers; + this.ShowXmlDocumentation = sect.Attribute("ShowXmlDocumentation") ?? this.ShowXmlDocumentation; + this.RemoveEmptyDefaultConstructors = sect.Attribute("RemoveEmptyDefaultConstructors") ?? this.RemoveEmptyDefaultConstructors; +// this.IntroduceIncrementAndDecrement = sect.Attribute("IntroduceIncrementAndDecrement") ?? this.IntroduceIncrementAndDecrement; +// this.MakeAssignmentExpressions = sect.Attribute("MakeAssignmentExpressions") ?? this.MakeAssignmentExpressions; +// this.AlwaysGenerateExceptionVariableForCatchBlocks = sect.Attribute("AlwaysGenerateExceptionVariableForCatchBlocks") ?? this.AlwaysGenerateExceptionVariableForCatchBlocks; + this.ShowTokenAndRvaComments = sect.Attribute("ShowTokenAndRvaComments") ?? this.ShowTokenAndRvaComments; + this.SortMembers = sect.Attribute("SortMembers") ?? this.SortMembers; + this.ForceShowAllMembers = sect.Attribute("ForceShowAllMembers") ?? this.ForceShowAllMembers; + this.SortSystemUsingStatementsFirst = sect.Attribute("SortSystemUsingStatementsFirst") ?? this.SortSystemUsingStatementsFirst; +// this.MaxArrayElements = sect.Attribute("MaxArrayElements") ?? this.MaxArrayElements; + //TODO: CSharpFormattingOptions + this.disableSave = false; + } + readonly bool disableSave; + + protected override void OnModified() { + if (disableSave) + return; + + var sect = settingsManager.RecreateSection(SETTINGS_GUID); + // Only save those settings that can be changed in the dialog box + sect.Attribute("DecompilationObject0", DecompilationObject0); + sect.Attribute("DecompilationObject1", DecompilationObject1); + sect.Attribute("DecompilationObject2", DecompilationObject2); + sect.Attribute("DecompilationObject3", DecompilationObject3); + sect.Attribute("DecompilationObject4", DecompilationObject4); + sect.Attribute("AnonymousMethods", AnonymousMethods); + sect.Attribute("ExpressionTrees", ExpressionTrees); + sect.Attribute("YieldReturn", YieldReturn); + sect.Attribute("AsyncAwait", AsyncAwait); +// sect.Attribute("AutomaticProperties", AutomaticProperties); +// sect.Attribute("AutomaticEvents", AutomaticEvents); +// sect.Attribute("UsingStatement", UsingStatement); +// sect.Attribute("ForEachStatement", ForEachStatement); +// sect.Attribute("LockStatement", LockStatement); +// sect.Attribute("SwitchStatementOnString", SwitchStatementOnString); +// sect.Attribute("UsingDeclarations", UsingDeclarations); + sect.Attribute("QueryExpressions", QueryExpressions); +// sect.Attribute("FullyQualifyAmbiguousTypeNames", FullyQualifyAmbiguousTypeNames); +// sect.Attribute("FullyQualifyAllTypes", FullyQualifyAllTypes); + sect.Attribute("UseDebugSymbols", UseDebugSymbols); +// sect.Attribute("ObjectOrCollectionInitializers", ObjectOrCollectionInitializers); + sect.Attribute("ShowXmlDocumentation", ShowXmlDocumentation); + sect.Attribute("RemoveEmptyDefaultConstructors", RemoveEmptyDefaultConstructors); +// sect.Attribute("IntroduceIncrementAndDecrement", IntroduceIncrementAndDecrement); +// sect.Attribute("MakeAssignmentExpressions", MakeAssignmentExpressions); +// sect.Attribute("AlwaysGenerateExceptionVariableForCatchBlocks", AlwaysGenerateExceptionVariableForCatchBlocks); + sect.Attribute("ShowTokenAndRvaComments", ShowTokenAndRvaComments); + sect.Attribute("SortMembers", SortMembers); + sect.Attribute("ForceShowAllMembers", ForceShowAllMembers); + sect.Attribute("SortSystemUsingStatementsFirst", SortSystemUsingStatementsFirst); +// sect.Attribute("MaxArrayElements", MaxArrayElements); + //TODO: CSharpFormattingOptions + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerSettingsTabCreator.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerSettingsTabCreator.cs new file mode 100644 index 000000000..139c02e36 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/DecompilerSettingsTabCreator.cs @@ -0,0 +1,42 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.Collections.Generic; +using System.ComponentModel.Composition; +using dnSpy.Contracts.Languages; +using ICSharpCode.Decompiler; + +namespace dnSpy.Languages.ILSpy.Settings { + [Export(typeof(IDecompilerSettingsTabCreator))] + sealed class DecompilerSettingsTabCreator : IDecompilerSettingsTabCreator { + readonly DecompilerSettings decompilerSettings; + readonly ILSettingsImpl ilSettings; + + [ImportingConstructor] + DecompilerSettingsTabCreator(DecompilerSettingsImpl decompilerSettings, ILSettingsImpl ilSettings) { + this.decompilerSettings = decompilerSettings; + this.ilSettings = ilSettings; + } + + public IEnumerable Create() { + yield return new CSharpDecompilerSettingsTab(decompilerSettings); + yield return new ILDecompilerSettingsTab(ilSettings); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILAstLanguageDecompilerSettings.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILAstLanguageDecompilerSettings.cs new file mode 100644 index 000000000..e94fd9979 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILAstLanguageDecompilerSettings.cs @@ -0,0 +1,49 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +#if DEBUG +using System.Collections.Generic; +using dnSpy.Contracts.Languages; + +namespace dnSpy.Languages.ILSpy.Settings { + sealed class ILAstLanguageDecompilerSettings : IDecompilerSettings { + public ILAstLanguageDecompilerSettings() { + } + + ILAstLanguageDecompilerSettings(ILAstLanguageDecompilerSettings other) { + } + + public IDecompilerSettings Clone() { + return new ILAstLanguageDecompilerSettings(this); + } + + public IEnumerable Options { + get { yield break; } + } + + public override bool Equals(object obj) { + return obj is ILAstLanguageDecompilerSettings; + } + + public override int GetHashCode() { + return 0; + } + } +} +#endif diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILDecompilerSettingsTab.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILDecompilerSettingsTab.cs new file mode 100644 index 000000000..a88298f7b --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILDecompilerSettingsTab.cs @@ -0,0 +1,67 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.ComponentModel; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.Settings.Dialog; +using dnSpy.Languages.ILSpy.Properties; + +namespace dnSpy.Languages.ILSpy.Settings { + sealed class ILDecompilerSettingsTab : IDecompilerSettingsTab, INotifyPropertyChanged { + readonly ILSettings _global_ilSettings; + readonly ILSettings ilSettings; + + public event PropertyChangedEventHandler PropertyChanged; + void OnPropertyChanged(string propName) { + if (PropertyChanged != null) + PropertyChanged(this, new PropertyChangedEventArgs(propName)); + } + + public double Order { + get { return LanguageConstants.ORDER_DECOMPILER_SETTINGS_ILSPY_IL; } + } + + public string Name { + get { return dnSpy_Languages_ILSpy_Resources.ILDecompilerSettingsTabName; } + } + + public ILSettings Settings { + get { return ilSettings; } + } + + public object UIObject { + get { return this; } + } + + public ILDecompilerSettingsTab(ILSettings ilSettings) { + this._global_ilSettings = ilSettings; + this.ilSettings = ilSettings.Clone(); + } + + public void OnClosed(bool saveSettings, IAppRefreshSettings appRefreshSettings) { + if (!saveSettings) + return; + + if (!_global_ilSettings.Equals(ilSettings)) + appRefreshSettings.Add(SettingsConstants.REDISASSEMBLE_IL_ILSPY_CODE); + + ilSettings.CopyTo(_global_ilSettings); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILLanguageDecompilerSettings.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILLanguageDecompilerSettings.cs new file mode 100644 index 000000000..583877967 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILLanguageDecompilerSettings.cs @@ -0,0 +1,84 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.Collections.Generic; +using System.Linq; +using dnSpy.Contracts.Languages; +using dnSpy.Languages.ILSpy.Properties; +using dnSpy.Languages.Settings; + +namespace dnSpy.Languages.ILSpy.Settings { + sealed class ILLanguageDecompilerSettings : IDecompilerSettings { + public ILSettings Settings { + get { return ilSettings; } + } + readonly ILSettings ilSettings; + + public ILLanguageDecompilerSettings(ILSettings ilSettings = null) { + this.ilSettings = ilSettings ?? new ILSettings(); + this.options = CreateOptions().ToArray(); + } + + public IDecompilerSettings Clone() { + return new ILLanguageDecompilerSettings(this.ilSettings.Clone()); + } + + public IEnumerable Options { + get { return options.AsEnumerable(); } + } + readonly IDecompilerOption[] options; + + IEnumerable CreateOptions() { + yield return new DecompilerOption(DecompilerOptionConstants.ShowILComments_GUID, + () => ilSettings.ShowILComments, a => ilSettings.ShowILComments = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_ShowILComments, + Name = DecompilerOptionConstants.ShowILComments_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ShowXmlDocumentation_GUID, + () => ilSettings.ShowXmlDocumentation, a => ilSettings.ShowXmlDocumentation = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_ShowXMLDocComments, + Name = DecompilerOptionConstants.ShowXmlDocumentation_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ShowTokenAndRvaComments_GUID, + () => ilSettings.ShowTokenAndRvaComments, a => ilSettings.ShowTokenAndRvaComments = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_ShowTokensRvasOffsets, + Name = DecompilerOptionConstants.ShowTokenAndRvaComments_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ShowILBytes_GUID, + () => ilSettings.ShowILBytes, a => ilSettings.ShowILBytes = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_ShowILInstrBytes, + Name = DecompilerOptionConstants.ShowILBytes_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.SortMembers_GUID, + () => ilSettings.SortMembers, a => ilSettings.SortMembers = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_SortMethods, + Name = DecompilerOptionConstants.SortMembers_NAME, + }; + } + + public override bool Equals(object obj) { + return obj is ILLanguageDecompilerSettings && + ilSettings.Equals(((ILLanguageDecompilerSettings)obj).ilSettings); + } + + public override int GetHashCode() { + return ilSettings.GetHashCode(); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILSettings.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILSettings.cs new file mode 100644 index 000000000..a1d7247a2 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/ILSettings.cs @@ -0,0 +1,159 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.ComponentModel.Composition; +using dnSpy.Contracts.Settings; +using dnSpy.Shared.MVVM; + +namespace dnSpy.Languages.ILSpy.Settings { + class ILSettings : ViewModelBase { + protected virtual void OnModified() { + } + + public bool ShowILComments { + get { return showILComments; } + set { + if (showILComments != value) { + showILComments = value; + OnPropertyChanged("ShowILComments"); + OnModified(); + } + } + } + bool showILComments = false; + + public bool ShowXmlDocumentation { + get { return showXmlDocumentation; } + set { + if (showXmlDocumentation != value) { + showXmlDocumentation = value; + OnPropertyChanged("ShowXmlDocumentation"); + OnModified(); + } + } + } + bool showXmlDocumentation = true; + + public bool ShowTokenAndRvaComments { + get { return showTokenAndRvaComments; } + set { + if (showTokenAndRvaComments != value) { + showTokenAndRvaComments = value; + OnPropertyChanged("ShowTokenAndRvaComments"); + OnModified(); + } + } + } + bool showTokenAndRvaComments = true; + + public bool ShowILBytes { + get { return showILBytes; } + set { + if (showILBytes != value) { + showILBytes = value; + OnPropertyChanged("ShowILBytes"); + OnModified(); + } + } + } + bool showILBytes = true; + + public bool SortMembers { + get { return sortMembers; } + set { + if (sortMembers != value) { + sortMembers = value; + OnPropertyChanged("SortMembers"); + OnModified(); + } + } + } + bool sortMembers = true; + + public ILSettings Clone() { + return CopyTo(new ILSettings()); + } + + public ILSettings CopyTo(ILSettings other) { + other.ShowILComments = this.ShowILComments; + other.ShowXmlDocumentation = this.ShowXmlDocumentation; + other.ShowTokenAndRvaComments = this.ShowTokenAndRvaComments; + other.ShowILBytes = this.ShowILBytes; + other.SortMembers = this.SortMembers; + return other; + } + + public override bool Equals(object obj) { + var other = obj as ILSettings; + return other != null && + ShowILComments == other.ShowILComments && + ShowXmlDocumentation == other.ShowXmlDocumentation && + ShowTokenAndRvaComments == other.ShowTokenAndRvaComments && + ShowILBytes == other.ShowILBytes && + SortMembers == other.SortMembers; + } + + public override int GetHashCode() { + uint h = 0; + + if (ShowILComments) h ^= 0x80000000; + if (ShowXmlDocumentation) h ^= 0x40000000; + if (ShowTokenAndRvaComments) h ^= 0x20000000; + if (ShowILBytes) h ^= 0x10000000; + if (SortMembers) h ^= 0x08000000; + + return (int)h; + } + } + + [Export, PartCreationPolicy(CreationPolicy.Shared)] + sealed class ILSettingsImpl : ILSettings { + static readonly Guid SETTINGS_GUID = new Guid("DD6752B1-5336-4601-A9B2-0879E18AE9F3"); + + readonly ISettingsManager settingsManager; + + [ImportingConstructor] + ILSettingsImpl(ISettingsManager settingsManager) { + this.settingsManager = settingsManager; + + this.disableSave = true; + var sect = settingsManager.GetOrCreateSection(SETTINGS_GUID); + this.ShowILComments = sect.Attribute("ShowILComments") ?? this.ShowILComments; + this.ShowXmlDocumentation = sect.Attribute("ShowXmlDocumentation") ?? this.ShowXmlDocumentation; + this.ShowTokenAndRvaComments = sect.Attribute("ShowTokenAndRvaComments") ?? this.ShowTokenAndRvaComments; + this.ShowILBytes = sect.Attribute("ShowILBytes") ?? this.ShowILBytes; + this.SortMembers = sect.Attribute("SortMembers") ?? this.SortMembers; + this.disableSave = false; + } + readonly bool disableSave; + + protected override void OnModified() { + if (disableSave) + return; + + var sect = settingsManager.RecreateSection(SETTINGS_GUID); + sect.Attribute("ShowILComments", ShowILComments); + sect.Attribute("ShowXmlDocumentation", ShowXmlDocumentation); + sect.Attribute("ShowTokenAndRvaComments", ShowTokenAndRvaComments); + sect.Attribute("ShowILBytes", ShowILBytes); + sect.Attribute("SortMembers", SortMembers); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/LanguageDecompilerSettings.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/LanguageDecompilerSettings.cs new file mode 100644 index 000000000..f2fc765f8 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/LanguageDecompilerSettings.cs @@ -0,0 +1,239 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.Collections.Generic; +using System.Diagnostics; +using System.Linq; +using dnSpy.Contracts.Languages; +using dnSpy.Languages.ILSpy.Properties; +using dnSpy.Languages.Settings; +using ICSharpCode.Decompiler; + +namespace dnSpy.Languages.ILSpy.Settings { + sealed class LanguageDecompilerSettings : IDecompilerSettings { + public DecompilerSettings Settings { + get { return decompilerSettings; } + } + readonly DecompilerSettings decompilerSettings; + + public LanguageDecompilerSettings(DecompilerSettings decompilerSettings = null) { + this.decompilerSettings = decompilerSettings ?? new DecompilerSettings(); + this.options = CreateOptions().ToArray(); + } + + public IDecompilerSettings Clone() { + return new LanguageDecompilerSettings(this.decompilerSettings.Clone()); + } + + public IEnumerable Options { + get { return options.AsEnumerable(); } + } + readonly IDecompilerOption[] options; + + IEnumerable CreateOptions() { + yield return new DecompilerOption(DecompilerOptionConstants.MemberOrder_GUID, + () => GetMemberOrder(), a => SetMemberOrder(a)) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompilationOrder, + Name = DecompilerOptionConstants.MemberOrder_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.AnonymousMethods_GUID, + () => decompilerSettings.AnonymousMethods, a => decompilerSettings.AnonymousMethods = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileAnonMethods, + Name = DecompilerOptionConstants.AnonymousMethods_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ExpressionTrees_GUID, + () => decompilerSettings.ExpressionTrees, a => decompilerSettings.ExpressionTrees = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileExprTrees, + Name = DecompilerOptionConstants.ExpressionTrees_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.YieldReturn_GUID, + () => decompilerSettings.YieldReturn, a => decompilerSettings.YieldReturn = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileEnumerators, + Name = DecompilerOptionConstants.YieldReturn_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.AsyncAwait_GUID, + () => decompilerSettings.AsyncAwait, a => decompilerSettings.AsyncAwait = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileAsyncMethods, + Name = DecompilerOptionConstants.AsyncAwait_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.AutomaticProperties_GUID, + () => decompilerSettings.AutomaticProperties, a => decompilerSettings.AutomaticProperties = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileAutoProps, + Name = DecompilerOptionConstants.AutomaticProperties_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.AutomaticEvents_GUID, + () => decompilerSettings.AutomaticEvents, a => decompilerSettings.AutomaticEvents = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileAutoEvents, + Name = DecompilerOptionConstants.AutomaticEvents_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.UsingStatement_GUID, + () => decompilerSettings.UsingStatement, a => decompilerSettings.UsingStatement = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileUsingStatements, + Name = DecompilerOptionConstants.UsingStatement_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ForEachStatement_GUID, + () => decompilerSettings.ForEachStatement, a => decompilerSettings.ForEachStatement = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileForeachStatements, + Name = DecompilerOptionConstants.ForEachStatement_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.LockStatement_GUID, + () => decompilerSettings.LockStatement, a => decompilerSettings.LockStatement = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileLockStatements, + Name = DecompilerOptionConstants.LockStatement_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.SwitchStatementOnString_GUID, + () => decompilerSettings.SwitchStatementOnString, a => decompilerSettings.SwitchStatementOnString = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileSwitchOnString, + Name = DecompilerOptionConstants.SwitchStatementOnString_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.UsingDeclarations_GUID, + () => decompilerSettings.UsingDeclarations, a => decompilerSettings.UsingDeclarations = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_AddUsingDeclarations, + Name = DecompilerOptionConstants.UsingDeclarations_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.QueryExpressions_GUID, + () => decompilerSettings.QueryExpressions, a => decompilerSettings.QueryExpressions = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_DecompileQueryExpr, + Name = DecompilerOptionConstants.QueryExpressions_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.FullyQualifyAmbiguousTypeNames_GUID, + () => decompilerSettings.FullyQualifyAmbiguousTypeNames, a => decompilerSettings.FullyQualifyAmbiguousTypeNames = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_FullyQualifyAmbiguousTypeNames, + Name = DecompilerOptionConstants.FullyQualifyAmbiguousTypeNames_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.FullyQualifyAllTypes_GUID, + () => decompilerSettings.FullyQualifyAllTypes, a => decompilerSettings.FullyQualifyAllTypes = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_FullyQualifyAllTypes, + Name = DecompilerOptionConstants.FullyQualifyAllTypes_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.UseDebugSymbols_GUID, + () => decompilerSettings.UseDebugSymbols, a => decompilerSettings.UseDebugSymbols = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_UseLocalNameFromSyms, + Name = DecompilerOptionConstants.UseDebugSymbols_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ObjectOrCollectionInitializers_GUID, + () => decompilerSettings.ObjectOrCollectionInitializers, a => decompilerSettings.ObjectOrCollectionInitializers = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_ObjectOrCollectionInitializers, + Name = DecompilerOptionConstants.ObjectOrCollectionInitializers_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ShowXmlDocumentation_GUID, + () => decompilerSettings.ShowXmlDocumentation, a => decompilerSettings.ShowXmlDocumentation = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_ShowXMLDocComments, + Name = DecompilerOptionConstants.ShowXmlDocumentation_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.RemoveEmptyDefaultConstructors_GUID, + () => decompilerSettings.RemoveEmptyDefaultConstructors, a => decompilerSettings.RemoveEmptyDefaultConstructors = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_RemoveEmptyDefaultCtors, + Name = DecompilerOptionConstants.RemoveEmptyDefaultConstructors_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.IntroduceIncrementAndDecrement_GUID, + () => decompilerSettings.IntroduceIncrementAndDecrement, a => decompilerSettings.IntroduceIncrementAndDecrement = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_IntroduceIncrementAndDecrement, + Name = DecompilerOptionConstants.IntroduceIncrementAndDecrement_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.MakeAssignmentExpressions_GUID, + () => decompilerSettings.MakeAssignmentExpressions, a => decompilerSettings.MakeAssignmentExpressions = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_MakeAssignmentExpressions, + Name = DecompilerOptionConstants.MakeAssignmentExpressions_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.AlwaysGenerateExceptionVariableForCatchBlocks_GUID, + () => decompilerSettings.AlwaysGenerateExceptionVariableForCatchBlocks, a => decompilerSettings.AlwaysGenerateExceptionVariableForCatchBlocks = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_AlwaysGenerateExceptionVariableForCatchBlocks, + Name = DecompilerOptionConstants.AlwaysGenerateExceptionVariableForCatchBlocks_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ShowTokenAndRvaComments_GUID, + () => decompilerSettings.ShowTokenAndRvaComments, a => decompilerSettings.ShowTokenAndRvaComments = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_ShowTokensRvasOffsets, + Name = DecompilerOptionConstants.ShowTokenAndRvaComments_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.SortMembers_GUID, + () => decompilerSettings.SortMembers, a => decompilerSettings.SortMembers = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_SortMethods, + Name = DecompilerOptionConstants.SortMembers_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.ForceShowAllMembers_GUID, + () => decompilerSettings.ForceShowAllMembers, a => decompilerSettings.ForceShowAllMembers = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_ShowCompilerGeneratedTypes, + Name = DecompilerOptionConstants.ForceShowAllMembers_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.SortSystemUsingStatementsFirst_GUID, + () => decompilerSettings.SortSystemUsingStatementsFirst, a => decompilerSettings.SortSystemUsingStatementsFirst = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_SortSystemFirst, + Name = DecompilerOptionConstants.SortSystemUsingStatementsFirst_NAME, + }; + yield return new DecompilerOption(DecompilerOptionConstants.MaxArrayElements_GUID, + () => decompilerSettings.MaxArrayElements, a => decompilerSettings.MaxArrayElements = a) { + Description = dnSpy_Languages_ILSpy_Resources.DecompilerSettings_MaxArrayElements, + Name = DecompilerOptionConstants.MaxArrayElements_NAME, + }; + } + + string GetMemberOrder() { + return GetMemberOrderString(decompilerSettings.DecompilationObject0) + + GetMemberOrderString(decompilerSettings.DecompilationObject1) + + GetMemberOrderString(decompilerSettings.DecompilationObject2) + + GetMemberOrderString(decompilerSettings.DecompilationObject3) + + GetMemberOrderString(decompilerSettings.DecompilationObject4); + } + + static string GetMemberOrderString(DecompilationObject d) { + switch (d) { + case DecompilationObject.NestedTypes: return "t"; + case DecompilationObject.Fields: return "f"; + case DecompilationObject.Events: return "e"; + case DecompilationObject.Properties: return "p"; + case DecompilationObject.Methods: return "m"; + default: + Debug.Fail("Shouldn't be here"); + return "?"; + } + } + + void SetMemberOrder(string s) { + if (s == null || s.Length != 5) + return; + decompilerSettings.DecompilationObject0 = GetDecompilationObject(s[0]) ?? decompilerSettings.DecompilationObject0; + decompilerSettings.DecompilationObject1 = GetDecompilationObject(s[1]) ?? decompilerSettings.DecompilationObject1; + decompilerSettings.DecompilationObject2 = GetDecompilationObject(s[2]) ?? decompilerSettings.DecompilationObject2; + decompilerSettings.DecompilationObject3 = GetDecompilationObject(s[3]) ?? decompilerSettings.DecompilationObject3; + decompilerSettings.DecompilationObject4 = GetDecompilationObject(s[4]) ?? decompilerSettings.DecompilationObject4; + } + + static DecompilationObject? GetDecompilationObject(char c) { + switch (c) { + case 't': return DecompilationObject.NestedTypes; + case 'f': return DecompilationObject.Fields; + case 'e': return DecompilationObject.Events; + case 'p': return DecompilationObject.Properties; + case 'm': return DecompilationObject.Methods; + } + return null; + } + + public override bool Equals(object obj) { + var other = obj as LanguageDecompilerSettings; + return other != null && + decompilerSettings.Equals(other.decompilerSettings); + } + + public override int GetHashCode() { + return decompilerSettings.GetHashCode(); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/LanguageSettingsManager.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/LanguageSettingsManager.cs new file mode 100644 index 000000000..5069a5037 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/LanguageSettingsManager.cs @@ -0,0 +1,66 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.ComponentModel.Composition; +using System.Threading; + +namespace dnSpy.Languages.ILSpy.Settings { + [Export, PartCreationPolicy(CreationPolicy.Shared)] + sealed class LanguageSettingsManager { + /// + /// Should only be used indirectly by dnSpy.Console.exe + /// + public static LanguageSettingsManager __Instance_DONT_USE { + get { + if (__instance_DONT_USE == null) + Interlocked.CompareExchange(ref __instance_DONT_USE, new LanguageSettingsManager(), null); + return __instance_DONT_USE; + } + } + static LanguageSettingsManager __instance_DONT_USE; + + LanguageSettingsManager() { + this.languageDecompilerSettings = new LanguageDecompilerSettings(); + this.ilLanguageDecompilerSettings = new ILLanguageDecompilerSettings(); + } + + [ImportingConstructor] + LanguageSettingsManager(DecompilerSettingsImpl decompilerSettings, ILSettingsImpl ilSettings) { + this.languageDecompilerSettings = new LanguageDecompilerSettings(decompilerSettings); + this.ilLanguageDecompilerSettings = new ILLanguageDecompilerSettings(ilSettings); + } + + public LanguageDecompilerSettings LanguageDecompilerSettings { + get { return languageDecompilerSettings; } + } + readonly LanguageDecompilerSettings languageDecompilerSettings; + + public ILLanguageDecompilerSettings ILLanguageDecompilerSettings { + get { return ilLanguageDecompilerSettings; } + } + readonly ILLanguageDecompilerSettings ilLanguageDecompilerSettings; + +#if DEBUG + public ILAstLanguageDecompilerSettings ILAstLanguageDecompilerSettings { + get { return ilAstLanguageDecompilerSettings; } + } + readonly ILAstLanguageDecompilerSettings ilAstLanguageDecompilerSettings = new ILAstLanguageDecompilerSettings(); +#endif + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/SettingsConstants.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/SettingsConstants.cs new file mode 100644 index 000000000..6814de7fc --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Settings/SettingsConstants.cs @@ -0,0 +1,44 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; + +namespace dnSpy.Languages.ILSpy.Settings { + static class SettingsConstants { + /// + /// Redisassemble IL (ILSpy) code + /// + public static readonly Guid REDISASSEMBLE_IL_ILSPY_CODE = new Guid("9F975119-FB7A-461D-BA17-09B82C7AE258"); + + /// + /// Redecompile ILAst (ILSpy) code + /// + public static readonly Guid REDECOMPILE_ILAST_ILSPY_CODE = new Guid("20D97DB7-EA2D-489D-820F-DCDCE3AB01D3"); + + /// + /// Redecompile C# (ILSpy) code + /// + public static readonly Guid REDECOMPILE_CSHARP_ILSPY_CODE = new Guid("00C8E462-E6E7-4D1F-8CE0-3385B34EA1FB"); + + /// + /// Redecompile VB (ILSpy) code + /// + public static readonly Guid REDECOMPILE_VB_ILSPY_CODE = new Guid("818B8011-851F-4868-9674-3AC3A7B0AEC6"); + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Themes/wpf.styles.templates.xaml b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Themes/wpf.styles.templates.xaml new file mode 100644 index 000000000..d559edda7 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/Themes/wpf.styles.templates.xaml @@ -0,0 +1,49 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/ILSpyEnvironmentProvider.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/ILSpyEnvironmentProvider.cs new file mode 100644 index 000000000..6653797aa --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/ILSpyEnvironmentProvider.cs @@ -0,0 +1,145 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Linq; +using dnlib.DotNet; +using dnSpy.Decompiler.Shared; +using ICSharpCode.Decompiler.Ast; +using ICSharpCode.NRefactory.TypeSystem; +using ICSharpCode.NRefactory.VB.Visitors; + +namespace dnSpy.Languages.ILSpy.VB { + sealed class ILSpyEnvironmentProvider : IEnvironmentProvider { + public string RootNamespace { + get { + return ""; + } + } + + public string GetTypeNameForAttribute(ICSharpCode.NRefactory.CSharp.Attribute attribute) { + var mr = attribute.Type.Annotations + .OfType() + .FirstOrDefault(); + return mr == null ? string.Empty : mr.FullName; + } + + public ICSharpCode.NRefactory.TypeSystem.IType ResolveType(ICSharpCode.NRefactory.VB.Ast.AstType type, ICSharpCode.NRefactory.VB.Ast.TypeDeclaration entity = null) { + /* + var annotation = type.Annotation(); + if (annotation == null ) + return null; + + IEntity current = null; + if (entity != null) { + var typeInfo = entity.Annotation(); + current = loader.ReadTypeReference(typeInfo).Resolve(context).GetDefinition(); + } + + return loader.ReadTypeReference(annotation, entity: current).Resolve(context);*/ + return SpecialType.UnknownType; + } + + public TypeKind GetTypeKindForAstType(ICSharpCode.NRefactory.CSharp.AstType type) { + var annotation = type.Annotation(); + if (annotation == null) + return TypeKind.Unknown; + + var definition = annotation.ResolveTypeDef(); + if (definition == null) + return TypeKind.Unknown; + if (definition.IsClass) + return TypeKind.Class; + if (definition.IsInterface) + return TypeKind.Interface; + if (definition.IsEnum) + return TypeKind.Enum; + if (definition.IsValueType) + return TypeKind.Struct; + + return TypeKind.Unknown; + } + + public TypeCode ResolveExpression(ICSharpCode.NRefactory.CSharp.Expression expression) { + var annotation = expression.Annotations.OfType().FirstOrDefault(); + + if (annotation == null || annotation.InferredType == null) + return TypeCode.Object; + + var definition = annotation.InferredType.ScopeType.ResolveTypeDef(); + + if (definition == null) + return TypeCode.Object; + + switch (definition.FullName) { + case "System.String": + return TypeCode.String; + default: + break; + } + + return TypeCode.Object; + } + + public Nullable IsReferenceType(ICSharpCode.NRefactory.CSharp.Expression expression) { + if (expression is ICSharpCode.NRefactory.CSharp.NullReferenceExpression) + return true; + + var annotation = expression.Annotations.OfType().FirstOrDefault(); + + if (annotation == null || annotation.InferredType == null) + return null; + + var definition = annotation.InferredType.ScopeType.ResolveTypeDef(); + + if (definition == null) + return null; + + return !definition.IsValueType; + } + + public IEnumerable CreateMemberSpecifiersForInterfaces(IEnumerable interfaces) { + foreach (var type in interfaces) { + var def = type.Annotation().ResolveTypeDef(); + if (def == null) + continue; + foreach (var method in def.Methods.Where(m => !m.Name.StartsWith("get_") && !m.Name.StartsWith("set_"))) { + yield return new ICSharpCode.NRefactory.VB.Ast.InterfaceMemberSpecifier((ICSharpCode.NRefactory.VB.Ast.AstType)type.Clone(), method.Name, TextTokenKindUtils.GetTextTokenKind(method)); + } + + foreach (var property in def.Properties) { + yield return new ICSharpCode.NRefactory.VB.Ast.InterfaceMemberSpecifier((ICSharpCode.NRefactory.VB.Ast.AstType)type.Clone(), property.Name, TextTokenKindUtils.GetTextTokenKind(property)); + } + } + } + + public bool HasEvent(ICSharpCode.NRefactory.VB.Ast.Expression expression) { + return expression.Annotation() != null; + } + + public bool IsMethodGroup(ICSharpCode.NRefactory.CSharp.Expression expression) { + var annotation = expression.Annotation(); + if (annotation != null) { + return true; + } + + return false; + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/VBLanguage.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/VBLanguage.cs new file mode 100644 index 000000000..5d3af6957 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/VBLanguage.cs @@ -0,0 +1,327 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.ComponentModel.Composition; +using dnlib.DotNet; +using dnSpy.Contracts.Languages; +using dnSpy.Languages.ILSpy.CSharp; +using dnSpy.Shared.Highlighting; +using ICSharpCode.Decompiler; +using ICSharpCode.Decompiler.Ast; +using ICSharpCode.Decompiler.Ast.Transforms; +using ICSharpCode.NRefactory.VB; +using ICSharpCode.NRefactory.VB.Visitors; +using dnSpy.Decompiler.Shared; +using dnSpy.Languages.ILSpy.Settings; +using System.Diagnostics; +using System.Text; + +namespace dnSpy.Languages.ILSpy.VB { + sealed class LanguageProvider : ILanguageProvider { + readonly LanguageSettingsManager languageSettingsManager; + + // Keep the default ctor. It's used by dnSpy.Console.exe + public LanguageProvider() + : this(LanguageSettingsManager.__Instance_DONT_USE) { + } + + public LanguageProvider(LanguageSettingsManager languageSettingsManager) { + Debug.Assert(languageSettingsManager != null); + if (languageSettingsManager == null) + throw new ArgumentNullException(); + this.languageSettingsManager = languageSettingsManager; + } + + public IEnumerable Languages { + get { yield return new VBLanguage(languageSettingsManager.LanguageDecompilerSettings); } + } + } + + [Export(typeof(ILanguageCreator))] + sealed class MyLanguageCreator : ILanguageCreator { + readonly LanguageSettingsManager languageSettingsManager; + + [ImportingConstructor] + MyLanguageCreator(LanguageSettingsManager languageSettingsManager) { + this.languageSettingsManager = languageSettingsManager; + } + + public IEnumerable Create() { + return new LanguageProvider(languageSettingsManager).Languages; + } + } + + /// + /// Decompiler logic for VB. + /// + sealed class VBLanguage : Language { + readonly Predicate transformAbortCondition = null; + readonly bool showAllMembers = false; + + public override IDecompilerSettings Settings { + get { return langSettings; } + } + readonly LanguageDecompilerSettings langSettings; + + public override double OrderUI { + get { return LanguageConstants.VB_ILSPY_ORDERUI; } + } + + public VBLanguage(LanguageDecompilerSettings langSettings) { + this.langSettings = langSettings; + } + + public override string GenericNameUI { + get { return LanguageConstants.GENERIC_NAMEUI_VB; } + } + + public override string UniqueNameUI { + get { return "VB"; } + } + + public override Guid GenericGuid { + get { return LanguageConstants.LANGUAGE_VB; } + } + + public override Guid UniqueGuid { + get { return LanguageConstants.LANGUAGE_VB_ILSPY; } + } + + public override string FileExtension { + get { return ".vb"; } + } + + public override string ProjectFileExtension { + get { return ".vbproj"; } + } + + public override void WriteCommentBegin(ITextOutput output, bool addSpace) { + if (addSpace) + output.Write("' ", TextTokenKind.Comment); + else + output.Write("'", TextTokenKind.Comment); + } + + public override void WriteCommentEnd(ITextOutput output, bool addSpace) { + } + + public override void Decompile(AssemblyDef asm, ITextOutput output, DecompilationContext ctx) { + WriteAssembly(asm, output, ctx); + + using (ctx.DisableAssemblyLoad()) { + var state = CreateAstBuilder(ctx, langSettings.Settings, currentModule: asm.ManifestModule); + try { + state.AstBuilder.AddAssembly(asm.ManifestModule, true, true, false); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + } + + public override void Decompile(ModuleDef mod, ITextOutput output, DecompilationContext ctx) { + WriteModule(mod, output, ctx); + + using (ctx.DisableAssemblyLoad()) { + var state = CreateAstBuilder(ctx, langSettings.Settings, currentModule: mod); + try { + state.AstBuilder.AddAssembly(mod, true, false, true); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + } + + public override void Decompile(MethodDef method, ITextOutput output, DecompilationContext ctx) { + WriteCommentLineDeclaringType(output, method); + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: method.DeclaringType, isSingleMember: true); + try { + state.AstBuilder.AddMethod(method); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + + public override void Decompile(PropertyDef property, ITextOutput output, DecompilationContext ctx) { + WriteCommentLineDeclaringType(output, property); + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: property.DeclaringType, isSingleMember: true); + try { + state.AstBuilder.AddProperty(property); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + + public override void Decompile(FieldDef field, ITextOutput output, DecompilationContext ctx) { + WriteCommentLineDeclaringType(output, field); + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: field.DeclaringType, isSingleMember: true); + try { + state.AstBuilder.AddField(field); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + + public override void Decompile(EventDef ev, ITextOutput output, DecompilationContext ctx) { + WriteCommentLineDeclaringType(output, ev); + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: ev.DeclaringType, isSingleMember: true); + try { + state.AstBuilder.AddEvent(ev); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + + public override void Decompile(TypeDef type, ITextOutput output, DecompilationContext ctx) { + var state = CreateAstBuilder(ctx, langSettings.Settings, currentType: type); + try { + state.AstBuilder.AddType(type); + RunTransformsAndGenerateCode(ref state, output, ctx); + } + finally { + state.Dispose(); + } + } + + public override bool ShowMember(IMemberRef member) { + return showAllMembers || !AstBuilder.MemberIsHidden(member, langSettings.Settings); + } + + void RunTransformsAndGenerateCode(ref BuilderState state, ITextOutput output, DecompilationContext ctx, IAstTransform additionalTransform = null) { + var astBuilder = state.AstBuilder; + astBuilder.RunTransformations(transformAbortCondition); + if (additionalTransform != null) { + additionalTransform.Run(astBuilder.SyntaxTree); + } + CSharpLanguage.AddXmlDocumentation(ref state, langSettings.Settings, astBuilder); + var csharpUnit = astBuilder.SyntaxTree; + csharpUnit.AcceptVisitor(new ICSharpCode.NRefactory.CSharp.InsertParenthesesVisitor() { InsertParenthesesForReadability = true }); + var unit = csharpUnit.AcceptVisitor(new CSharpToVBConverterVisitor(new ILSpyEnvironmentProvider()), null); + var outputFormatter = new VBTextOutputFormatter(output); + var formattingPolicy = new VBFormattingOptions(); + unit.AcceptVisitor(new OutputVisitor(outputFormatter, formattingPolicy), null); + } + + BuilderState CreateAstBuilder(DecompilationContext ctx, DecompilerSettings settings, ModuleDef currentModule = null, TypeDef currentType = null, bool isSingleMember = false) { + if (currentModule == null) + currentModule = currentType.Module; + settings = settings.Clone(); + if (isSingleMember) + settings.UsingDeclarations = false; + settings.IntroduceIncrementAndDecrement = false; + settings.MakeAssignmentExpressions = false; + settings.QueryExpressions = false; + settings.AlwaysGenerateExceptionVariableForCatchBlocks = true; + var cache = ctx.GetOrCreate(); + var state = new BuilderState(ctx, cache); + state.AstBuilder.Context.CurrentModule = currentModule; + state.AstBuilder.Context.CancellationToken = ctx.CancellationToken; + state.AstBuilder.Context.CurrentType = currentType; + state.AstBuilder.Context.Settings = settings; + return state; + } + + protected override void FormatTypeName(ITextOutput output, TypeDef type) { + if (type == null) + throw new ArgumentNullException("type"); + + TypeToString(output, ConvertTypeOptions.DoNotUsePrimitiveTypeNames | ConvertTypeOptions.IncludeTypeParameterDefinitions, type); + } + + protected override void TypeToString(ITextOutput output, ITypeDefOrRef type, bool includeNamespace, IHasCustomAttribute typeAttributes = null) { + ConvertTypeOptions options = ConvertTypeOptions.IncludeTypeParameterDefinitions; + if (includeNamespace) + options |= ConvertTypeOptions.IncludeNamespace; + + TypeToString(output, options, type, typeAttributes); + } + + void TypeToString(ITextOutput output, ConvertTypeOptions options, ITypeDefOrRef type, IHasCustomAttribute typeAttributes = null) { + var envProvider = new ILSpyEnvironmentProvider(); + var converter = new CSharpToVBConverterVisitor(envProvider); + var astType = AstBuilder.ConvertType(type, new StringBuilder(), typeAttributes, options); + + if (type.TryGetByRefSig() != null) { + output.Write("ByRef", TextTokenKind.Keyword); + output.WriteSpace(); + if (astType is ICSharpCode.NRefactory.CSharp.ComposedType && ((ICSharpCode.NRefactory.CSharp.ComposedType)astType).PointerRank > 0) + ((ICSharpCode.NRefactory.CSharp.ComposedType)astType).PointerRank--; + } + + var vbAstType = astType.AcceptVisitor(converter, null); + + vbAstType.AcceptVisitor(new OutputVisitor(new VBTextOutputFormatter(output), new VBFormattingOptions()), null); + } + + public override bool CanDecompile(DecompilationType decompilationType) { + switch (decompilationType) { + case DecompilationType.PartialType: + case DecompilationType.AssemblyInfo: + return true; + } + return base.CanDecompile(decompilationType); + } + + public override void Decompile(DecompilationType decompilationType, object data) { + switch (decompilationType) { + case DecompilationType.PartialType: + DecompilePartial((DecompilePartialType)data); + return; + case DecompilationType.AssemblyInfo: + DecompileAssemblyInfo((DecompileAssemblyInfo)data); + return; + } + base.Decompile(decompilationType, data); + } + + void DecompilePartial(DecompilePartialType info) { + var state = CreateAstBuilder(info.Context, CSharpLanguage.CreateDecompilerSettings(langSettings.Settings, info.UseUsingDeclarations), currentType: info.Type); + try { + state.AstBuilder.AddType(info.Type); + RunTransformsAndGenerateCode(ref state, info.Output, info.Context, new DecompilePartialTransform(info.Type, info.Definitions, info.ShowDefinitions, info.AddPartialKeyword, info.InterfacesToRemove)); + } + finally { + state.Dispose(); + } + } + + void DecompileAssemblyInfo(DecompileAssemblyInfo info) { + var state = CreateAstBuilder(info.Context, langSettings.Settings, currentModule: info.Module); + try { + state.AstBuilder.AddAssembly(info.Module, true, info.Module.IsManifestModule, true); + RunTransformsAndGenerateCode(ref state, info.Output, info.Context, new AssemblyInfoTransform()); + } + finally { + state.Dispose(); + } + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/VBTextOutputFormatter.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/VBTextOutputFormatter.cs new file mode 100644 index 000000000..83875bd01 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/VB/VBTextOutputFormatter.cs @@ -0,0 +1,295 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Diagnostics; +using dnlib.DotNet; +using dnSpy.Decompiler.Shared; +using ICSharpCode.Decompiler.ILAst; +using ICSharpCode.NRefactory.VB; +using ICSharpCode.NRefactory.VB.Ast; + +namespace dnSpy.Languages.ILSpy.VB { + sealed class VBTextOutputFormatter : IOutputFormatter { + readonly ITextOutput output; + readonly Stack nodeStack = new Stack(); + + public VBTextOutputFormatter(ITextOutput output) { + if (output == null) + throw new ArgumentNullException("output"); + this.output = output; + } + + MemberMapping currentMemberMapping; + Stack parentMemberMappings = new Stack(); + List>> multiMappings; + + public void StartNode(AstNode node) { +// var ranges = node.Annotation>(); +// if (ranges != null && ranges.Count > 0) +// { +// // find the ancestor that has method mapping as annotation +// if (node.Ancestors != null && node.Ancestors.Count() > 0) +// { +// var n = node.Ancestors.FirstOrDefault(a => a.Annotation() != null); +// if (n != null) { +// MemberMapping mapping = n.Annotation(); +// +// // add all ranges +// foreach (var range in ranges) { +// mapping.MemberCodeMappings.Add(new SourceCodeMapping { +// ILInstructionOffset = range, +// SourceCodeLine = output.CurrentLine, +// MemberMapping = mapping +// }); +// } +// } +// } +// } + + nodeStack.Push(node); + + MemberMapping mapping = node.Annotation(); + if (mapping != null) { + parentMemberMappings.Push(currentMemberMapping); + currentMemberMapping = mapping; + } + // For ctor/cctor field initializers + var mms = node.Annotation>>>(); + if (mms != null) { + Debug.Assert(multiMappings == null); + multiMappings = mms; + } + } + + public void EndNode(AstNode node) { + if (nodeStack.Pop() != node) + throw new InvalidOperationException(); + + if (node.Annotation() != null) { + output.AddDebugSymbols(currentMemberMapping); + currentMemberMapping = parentMemberMappings.Pop(); + } + var mms = node.Annotation>>>(); + if (mms != null) { + Debug.Assert(mms == multiMappings); + if (mms == multiMappings) { + foreach (var mm in mms) + output.AddDebugSymbols(mm.Item1); + multiMappings = null; + } + } + } + + public void WriteIdentifier(string identifier, TextTokenKind tokenKind) { + var definition = GetCurrentDefinition(); + if (definition != null) { + output.WriteDefinition(IdentifierEscaper.Escape(identifier), definition, tokenKind); + return; + } + + object memberRef = GetCurrentMemberReference(); + if (memberRef != null) { + output.WriteReference(IdentifierEscaper.Escape(identifier), memberRef, tokenKind); + return; + } + + definition = GetCurrentLocalDefinition(); + if (definition != null) { + output.WriteDefinition(IdentifierEscaper.Escape(identifier), definition, tokenKind); + return; + } + + memberRef = GetCurrentLocalReference(); + if (memberRef != null) { + output.WriteReference(IdentifierEscaper.Escape(identifier), memberRef, tokenKind, true); + return; + } + + output.Write(IdentifierEscaper.Escape(identifier), tokenKind); + } + + IMemberRef GetCurrentMemberReference() { + AstNode node = nodeStack.Peek(); + IMemberRef memberRef = node.Annotation(); + if (memberRef == null && node.Role == AstNode.Roles.TargetExpression && (node.Parent is InvocationExpression || node.Parent is ObjectCreationExpression)) { + memberRef = node.Parent.Annotation(); + } + return memberRef; + } + + object GetCurrentLocalReference() { + AstNode node = nodeStack.Peek(); + ILVariable variable = node.Annotation(); + if (variable != null) { + if (variable.OriginalParameter != null) + return variable.OriginalParameter; + //if (variable.OriginalVariable != null) + // return variable.OriginalVariable; + return variable; + } + return null; + } + + object GetCurrentLocalDefinition() { + AstNode node = nodeStack.Peek(); + var parameterDef = node.Annotation(); + if (parameterDef != null) + return parameterDef; + + if (node is VariableInitializer || node is CatchBlock || node is ForEachStatement) { + var variable = node.Annotation(); + if (variable != null) { + if (variable.OriginalParameter != null) + return variable.OriginalParameter; + //if (variable.OriginalVariable != null) + // return variable.OriginalVariable; + return variable; + } + else { + + } + } + + return null; + } + + object GetCurrentDefinition() { + if (nodeStack == null || nodeStack.Count == 0) + return null; + + var node = nodeStack.Peek(); + if (IsDefinition(node)) + return node.Annotation(); + + node = node.Parent; + if (IsDefinition(node)) + return node.Annotation(); + + return null; + } + + public void WriteKeyword(string keyword) { + IMemberRef memberRef = GetCurrentMemberReference(); + var node = nodeStack.Peek(); + if (memberRef != null && node is PrimitiveType) + output.WriteReference(keyword, memberRef, TextTokenKind.Keyword); + else + output.Write(keyword, TextTokenKind.Keyword); + } + + public void WriteToken(string token, TextTokenKind tokenKind) { + // Attach member reference to token only if there's no identifier in the current node. + IMemberRef memberRef = GetCurrentMemberReference(); + if (memberRef != null && nodeStack.Peek().GetChildByRole(AstNode.Roles.Identifier).IsNull) + output.WriteReference(token, memberRef, tokenKind); + else + output.Write(token, tokenKind); + } + + public void Space() { + output.WriteSpace(); + } + + public void Indent() { + output.Indent(); + } + + public void Unindent() { + output.Unindent(); + } + + public void NewLine() { + output.WriteLine(); + } + + public void WriteComment(bool isDocumentation, string content) { + if (isDocumentation) { + output.Write("'''", TextTokenKind.XmlDocTag); + output.WriteXmlDoc(content); + output.WriteLine(); + } + else + output.WriteLine("'" + content, TextTokenKind.Comment); + } + + static bool IsDefinition(AstNode node) { + return + node is FieldDeclaration || + node is ConstructorDeclaration || + node is EventDeclaration || + node is DelegateDeclaration || + node is OperatorDeclaration || + node is MemberDeclaration || + node is TypeDeclaration; + } + + class DebugState { + public List Nodes = new List(); + public List ExtraILRanges = new List(); + public TextPosition StartLocation; + } + readonly Stack debugStack = new Stack(); + public void DebugStart(AstNode node) { + debugStack.Push(new DebugState { StartLocation = output.Location }); + } + + public void DebugHidden(object hiddenILRanges) { + var list = hiddenILRanges as IList; + if (list != null) { + if (debugStack.Count > 0) + debugStack.Peek().ExtraILRanges.AddRange(list); + } + } + + public void DebugExpression(AstNode node) { + if (debugStack.Count > 0) + debugStack.Peek().Nodes.Add(node); + } + + static readonly IEnumerable emptyILRange = new ILRange[0]; + public void DebugEnd(AstNode node) { + var state = debugStack.Pop(); + if (currentMemberMapping != null) { + foreach (var range in ILRange.OrderAndJoin(GetILRanges(state))) + currentMemberMapping.MemberCodeMappings.Add(new SourceCodeMapping(range, state.StartLocation, output.Location, currentMemberMapping)); + } + else if (multiMappings != null) { + foreach (var mm in multiMappings) { + foreach (var range in ILRange.OrderAndJoin(mm.Item2)) + mm.Item1.MemberCodeMappings.Add(new SourceCodeMapping(range, state.StartLocation, output.Location, mm.Item1)); + } + } + } + + static IEnumerable GetILRanges(DebugState state) { + foreach (var node in state.Nodes) { + foreach (var ann in node.Annotations) { + var list = ann as IList; + if (list == null) + continue; + foreach (var range in list) + yield return range; + } + } + foreach (var range in state.ExtraILRanges) + yield return range; + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/AddXmlDocTransform.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/AddXmlDocTransform.cs new file mode 100644 index 000000000..695ba3cdc --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/AddXmlDocTransform.cs @@ -0,0 +1,65 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 ICSharpCode.NRefactory.CSharp; +using dnlib.DotNet; +using dnSpy.Shared.Languages.XmlDoc; +using System.Text; + +namespace dnSpy.Languages.ILSpy.XmlDoc { + /// + /// Adds XML documentation for member definitions. + /// + struct AddXmlDocTransform { + readonly StringBuilder stringBuilder; + + public AddXmlDocTransform(StringBuilder sb) { + this.stringBuilder = sb; + } + + public void Run(AstNode node) { + if (node is EntityDeclaration) { + IMemberRef mr = node.Annotation(); + if (mr != null && mr.Module != null) { + var xmldoc = XmlDocLoader.LoadDocumentation(mr.Module); + if (xmldoc != null) { + string doc = xmldoc.GetDocumentation(XmlDocKeyProvider.GetKey(mr, stringBuilder)); + if (!string.IsNullOrEmpty(doc)) { + InsertXmlDocumentation(node, doc); + } + } + } + if (!(node is TypeDeclaration)) + return; // don't recurse into attributed nodes, except for type definitions + } + foreach (AstNode child in node.Children) + Run(child); + } + + void InsertXmlDocumentation(AstNode node, string doc) { + foreach (var info in new XmlDocLine(doc)) { + stringBuilder.Clear(); + if (info != null) { + stringBuilder.Append(' '); + info.Value.WriteTo(stringBuilder); + } + node.Parent.InsertChildBefore(node, new Comment(stringBuilder.ToString(), CommentType.Documentation), Roles.Comment); + } + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/StringLineIterator.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/StringLineIterator.cs new file mode 100644 index 000000000..cfb59f9d3 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/StringLineIterator.cs @@ -0,0 +1,98 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections; +using System.Collections.Generic; +using System.Diagnostics; + +namespace dnSpy.Languages.ILSpy.XmlDoc { + struct SubStringInfo { + public readonly int Index; + public readonly int Length; + + public SubStringInfo(int index, int length) { + this.Index = index; + this.Length = length; + } + } + + struct StringLineIterator : IEnumerable, IEnumerator { + readonly string s; + int index; + readonly int end; + SubStringInfo info; + bool finished; + + public StringLineIterator(string s, int index, int length) { + this.s = s; + this.index = index; + this.end = index + length; + this.info = default(SubStringInfo); + this.finished = false; + } + + public StringLineIterator GetEnumerator() { + return this; + } + + IEnumerator IEnumerable.GetEnumerator() { + Debug.Fail("'this' was boxed"); + return GetEnumerator(); + } + + IEnumerator IEnumerable.GetEnumerator() { + Debug.Fail("'this' was boxed"); + return GetEnumerator(); + } + + public SubStringInfo Current { + get { return info; } + } + + object IEnumerator.Current { + get { Debug.Fail("'this' was boxed"); return info; } + } + + public void Dispose() { + } + + public bool MoveNext() { + int newLineIndex = this.s.IndexOfAny(newLineChars, this.index, end - this.index); + if (newLineIndex < 0) { + if (this.finished) + return false; + this.info = new SubStringInfo(this.index, end - this.index); + this.finished = true; + return true; + } + int len = newLineIndex - this.index; + this.info = new SubStringInfo(this.index, len); + if (s[newLineIndex] == '\r' && newLineIndex + 1 < s.Length && s[newLineIndex + 1] == '\n') + newLineIndex++; + this.index = newLineIndex + 1; + return true; + } + static readonly char[] newLineChars = new char[] { '\r', '\n' }; + + public void Reset() { + throw new NotImplementedException(); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/SubString.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/SubString.cs new file mode 100644 index 000000000..60e1efb28 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/SubString.cs @@ -0,0 +1,42 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.Text; + +namespace dnSpy.Languages.ILSpy.XmlDoc { + struct SubString { + public readonly string String; + public readonly int Index; + public readonly int Length; + + public SubString(string s, int index, int length) { + this.String = s; + this.Index = index; + this.Length = length; + } + + public override string ToString() { + return this.String.Substring(this.Index, this.Length); + } + + public void WriteTo(StringBuilder sb) { + sb.Append(this.String, this.Index, this.Length); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/XmlDocLine.cs b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/XmlDocLine.cs new file mode 100644 index 000000000..3edd02490 --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/XmlDoc/XmlDocLine.cs @@ -0,0 +1,163 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections; +using System.Collections.Generic; +using System.Diagnostics; + +namespace dnSpy.Languages.ILSpy.XmlDoc { + struct XmlDocLine : IEnumerable, IEnumerator { + readonly string s; + readonly int start; + readonly int end; + SubString? current; + SubStringInfo? indent; + StringLineIterator iter; + int emptyLines; + + public XmlDocLine(string s) + : this(s, 0, s.Length) { + } + + public XmlDocLine(string s, int start, int length) { + this.s = s; + this.start = start; + this.end = start + length; + this.current = null; + this.indent = null; + this.iter = new StringLineIterator(s, start, end - start); + this.emptyLines = 0; + } + + public XmlDocLine GetEnumerator() { + return this; + } + + IEnumerator IEnumerable.GetEnumerator() { + Debug.Fail("'this' was boxed"); + return GetEnumerator(); + } + + IEnumerator IEnumerable.GetEnumerator() { + Debug.Fail("'this' was boxed"); + return GetEnumerator(); + } + + public SubString? Current { + get { return current; } + } + + object IEnumerator.Current { + get { Debug.Fail("'this' was boxed"); return current; } + } + + public void Dispose() { + } + + public bool MoveNext() { + if (this.indent == null) { + for (;;) { + if (!iter.MoveNext()) + return false; + if (!IsWhiteSpace(s, iter.Current)) + break; + } + + indent = GetIndentation(s, iter.Current); + goto start2; + } + + if (emptyLines != 0) + goto start2; +start: + if (!iter.MoveNext()) + return false; +start2: + if (IsWhiteSpace(s, iter.Current)) { + emptyLines++; + goto start; + } + + if (emptyLines != 0) { + if (emptyLines != -1) { + emptyLines--; + if (emptyLines == 0) + emptyLines = -1; + current = null; + return true; + } + emptyLines = 0; + } + + int index, end; + Trim(out index, out end); + current = new SubString(s, index, end - index); + return true; + } + + void Trim(out int trimmedIndex, out int trimmedEnd) { + Debug.Assert(indent != null); + + int index = iter.Current.Index; + int end = index + iter.Current.Length; + if (indent.Value.Length > iter.Current.Length) { + trimmedIndex = index; + trimmedEnd = end; + return; + } + + int end2 = index + indent.Value.Length; + for (int i = index, j = indent.Value.Index; i < end2; i++, j++) { + if (s[i] != s[j]) { + trimmedIndex = index; + trimmedEnd = end; + return; + } + } + + trimmedIndex = index + indent.Value.Length; + trimmedEnd = end; + Debug.Assert(trimmedIndex <= trimmedEnd); + } + + SubStringInfo GetIndentation(string doc, SubStringInfo info) { + int end = info.Index + info.Length; + int i = info.Index; + for (; i < end; i++) { + if (!char.IsWhiteSpace(doc[i])) + break; + } + return new SubStringInfo(info.Index, i - info.Index); + } + + bool IsWhiteSpace(string doc, SubStringInfo info) { + int end = info.Index + info.Length; + for (int i = info.Index; i < end; i++) { + if (!char.IsWhiteSpace(doc[i])) + return false; + } + return true; + } + + public void Reset() { + throw new NotImplementedException(); + } + } +} diff --git a/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/dnSpy.Languages.ILSpy.csproj b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/dnSpy.Languages.ILSpy.csproj new file mode 100644 index 000000000..486b281ce --- /dev/null +++ b/Plugins/ILSpy.Decompiler/dnSpy.Languages.ILSpy/dnSpy.Languages.ILSpy.csproj @@ -0,0 +1,146 @@ + + + + + Debug + AnyCPU + {D7FE873E-DF22-4F54-AEFA-BCF33AFD7E05} + Library + Properties + dnSpy.Languages.ILSpy + Languages.ILSpy.Plugin + v4.6 + 512 + True + ..\..\..\dnSpy.snk + + + true + full + false + ..\..\..\dnSpy\dnSpy\bin\Debug\ + DEBUG;TRACE + prompt + 4 + 1685 + ..\..\..\dnSpy\dnSpy\bin\Debug\Languages.ILSpy.Plugin.XML + + + pdbonly + true + ..\..\..\dnSpy\dnSpy\bin\Release\ + TRACE + prompt + 4 + 1685 + ..\..\..\dnSpy\dnSpy\bin\Release\Languages.ILSpy.Plugin.XML + + + + + + + + + + + + + + + + + + True + True + dnSpy.Languages.ILSpy.Resources.resx + + + + + + + + + + + + + + + + + + + + + + + + + + + {fdfc1237-143f-4919-8318-4926901f4639} + dnlib + + + {9b234472-0e22-428c-9345-c8d9ee5e06af} + dnSpy.Contracts + + + {a027546a-cf4b-47f9-bc53-ee1ad424ee41} + dnSpy.Decompiler.Shared + + + {7e7c2cf8-2057-4eaa-9dad-ab3022cf4037} + dnSpy.Shared + + + {984cc812-9470-4a13-aff9-cc44068d666c} + ICSharpCode.Decompiler + + + {9265e4ea-eb00-4cb6-8a9a-608871e24fd0} + dnSpy.Languages + + + {53dca265-3c3c-42f9-b647-f72ba678122b} + ICSharpCode.NRefactory.CSharp + + + {3b2a5653-ec97-4001-bb9b-d90f1af2c371} + ICSharpCode.NRefactory + + + {7b82b671-419f-45f4-b778-d9286f996efa} + ICSharpCode.NRefactory.VB + + + + + PublicResXFileCodeGenerator + dnSpy.Languages.ILSpy.Resources.Designer.cs + + + + + + + MSBuild:Compile + Designer + + + + + Properties\AssemblyInfo.Shared.cs + + + + + \ No newline at end of file diff --git a/Plugins/dnSpy.Analyzer/AnalyzerManager.cs b/Plugins/dnSpy.Analyzer/AnalyzerManager.cs new file mode 100644 index 000000000..639bb5219 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/AnalyzerManager.cs @@ -0,0 +1,391 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections.Generic; +using System.ComponentModel; +using System.ComponentModel.Composition; +using System.Diagnostics; +using System.Linq; +using System.Windows; +using System.Windows.Input; +using dnlib.DotNet; +using dnSpy.Analyzer.TreeNodes; +using dnSpy.Contracts.Controls; +using dnSpy.Contracts.Decompiler; +using dnSpy.Contracts.Files; +using dnSpy.Contracts.Files.Tabs; +using dnSpy.Contracts.Files.Tabs.TextEditor; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.Menus; +using dnSpy.Contracts.TextEditor; +using dnSpy.Contracts.Themes; +using dnSpy.Contracts.TreeView; +using dnSpy.Decompiler.Shared; +using dnSpy.Shared.MVVM; + +namespace dnSpy.Analyzer { + interface IAnalyzerManager { + /// + /// Gets the instance + /// + ITreeView TreeView { get; } + + /// + /// Called when it's been closed + /// + void OnClose(); + + /// + /// Adds if it hasn't been added and gives it focus. + /// + /// Node + void Add(IAnalyzerTreeNodeData node); + + /// + /// Called by when its method + /// has been called. + /// + /// Activated node (it's the caller) + void OnActivated(IAnalyzerTreeNodeData node); + + /// + /// Follows the reference + /// + /// Node + /// true to show it in a new tab + /// true to show the reference in a method body + void FollowNode(ITreeNodeData node, bool newTab, bool? useCodeRef); + + /// + /// Returns true if can execute + /// + /// Node + /// true to show the reference in a method body + /// + bool CanFollowNode(ITreeNodeData node, bool useCodeRef); + } + + [Export, Export(typeof(IAnalyzerManager)), PartCreationPolicy(CreationPolicy.Shared)] + sealed class AnalyzerManager : IAnalyzerManager, ITreeViewListener { + static readonly Guid ANALYZER_TREEVIEW_GUID = new Guid("8981898A-1384-4B67-9577-3CB096195146"); + + public ITreeView TreeView { + get { return treeView; } + } + readonly ITreeView treeView; + + sealed class GuidObjectsCreator : IGuidObjectsCreator { + readonly ITreeView treeView; + + public GuidObjectsCreator(ITreeView treeView) { + this.treeView = treeView; + } + + public IEnumerable GetGuidObjects(GuidObject creatorObject, bool openedFromKeyboard) { + yield return new GuidObject(MenuConstants.GUIDOBJ_TREEVIEW_NODES_ARRAY_GUID, treeView.TopLevelSelection); + } + } + + readonly AnalyzerTreeNodeDataContext context; + readonly IFileTabManager fileTabManager; + + [ImportingConstructor] + AnalyzerManager(IWpfCommandManager wpfCommandManager, IFileTabManager fileTabManager, ITreeViewManager treeViewManager, IMenuManager menuManager, IThemeManager themeManager, IAnalyzerSettings analyzerSettings, IDotNetImageManager dotNetImageManager, ILanguageManager languageManager) { + this.fileTabManager = fileTabManager; + + this.context = new AnalyzerTreeNodeDataContext { + DotNetImageManager = dotNetImageManager, + Language = languageManager.Language, + FileManager = fileTabManager.FileTreeView.FileManager, + ShowToken = analyzerSettings.ShowToken, + SingleClickExpandsChildren = analyzerSettings.SingleClickExpandsChildren, + SyntaxHighlight = analyzerSettings.SyntaxHighlight, + UseNewRenderer = analyzerSettings.UseNewRenderer, + AnalyzerManager = this, + }; + + var options = new TreeViewOptions { + CanDragAndDrop = false, + TreeViewListener = this, + }; + this.treeView = treeViewManager.Create(ANALYZER_TREEVIEW_GUID, options); + + fileTabManager.FileTreeView.FileManager.CollectionChanged += FileManager_CollectionChanged; + fileTabManager.FileModified += FileTabManager_FileModified; + languageManager.LanguageChanged += LanguageManager_LanguageChanged; + themeManager.ThemeChanged += ThemeManager_ThemeChanged; + analyzerSettings.PropertyChanged += AnalyzerSettings_PropertyChanged; + + menuManager.InitializeContextMenu((FrameworkElement)this.treeView.UIObject, new Guid(MenuConstants.GUIDOBJ_ANALYZER_TREEVIEW_GUID), new GuidObjectsCreator(this.treeView)); + wpfCommandManager.Add(CommandConstants.GUID_ANALYZER_TREEVIEW, (UIElement)this.treeView.UIObject); + var cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_ANALYZER_TREEVIEW); + var command = new RelayCommand(a => ActivateNode()); + cmds.Add(command, ModifierKeys.Control, Key.Enter); + cmds.Add(command, ModifierKeys.Shift, Key.Enter); + } + + void FileTabManager_FileModified(object sender, FileModifiedEventArgs e) { + AnalyzerTreeNodeData.HandleModelUpdated(treeView.Root, e.Files); + RefreshNodes(); + } + + void ActivateNode() { + var nodes = treeView.TopLevelSelection; + var node = nodes.Length == 0 ? null : nodes[0] as ITreeNodeData; + if (node != null) + node.Activate(); + } + + void FileManager_CollectionChanged(object sender, NotifyFileCollectionChangedEventArgs e) { + switch (e.Type) { + case NotifyFileCollectionType.Clear: + ClearAll(); + break; + + case NotifyFileCollectionType.Add: + AnalyzerTreeNodeData.HandleAssemblyListChanged(treeView.Root, new IDnSpyFile[0], e.Files); + break; + + case NotifyFileCollectionType.Remove: + AnalyzerTreeNodeData.HandleAssemblyListChanged(treeView.Root, e.Files, new IDnSpyFile[0]); + break; + + default: + break; + } + } + + void LanguageManager_LanguageChanged(object sender, EventArgs e) { + this.context.Language = ((ILanguageManager)sender).Language; + RefreshNodes(); + } + + void AnalyzerSettings_PropertyChanged(object sender, PropertyChangedEventArgs e) { + var analyzerSettings = (IAnalyzerSettings)sender; + switch (e.PropertyName) { + case "ShowToken": + context.ShowToken = analyzerSettings.ShowToken; + RefreshNodes(); + break; + + case "SyntaxHighlight": + context.SyntaxHighlight = analyzerSettings.SyntaxHighlight; + RefreshNodes(); + break; + + case "UseNewRenderer": + context.UseNewRenderer = analyzerSettings.UseNewRenderer; + RefreshNodes(); + break; + } + } + + void ThemeManager_ThemeChanged(object sender, ThemeChangedEventArgs e) { + RefreshNodes(); + } + + void RefreshNodes() { + this.treeView.RefreshAllNodes(); + } + + void ITreeViewListener.OnEvent(ITreeView treeView, TreeViewListenerEventArgs e) { + if (e.Event == TreeViewListenerEvent.NodeCreated) { + Debug.Assert(context != null); + var node = (ITreeNode)e.Argument; + var d = node.Data as IAnalyzerTreeNodeData; + if (d != null) + d.Context = context; + return; + } + } + + void Cancel() { + AnalyzerTreeNodeData.CancelSelfAndChildren(treeView.Root.Data); + } + + public void OnClose() { + ClearAll(); + } + + void ClearAll() { + Cancel(); + this.treeView.Root.Children.Clear(); + } + + public void Add(IAnalyzerTreeNodeData node) { + if (node is EntityNode) { + var an = node as EntityNode; + var found = this.treeView.Root.DataChildren.OfType().FirstOrDefault(n => n.Member == an.Member); + if (found != null) { + found.TreeNode.IsExpanded = true; + this.treeView.SelectItems(new ITreeNodeData[] { found }); + this.treeView.Focus(); + return; + } + } + this.treeView.Root.Children.Add(this.treeView.Create(node)); + node.TreeNode.IsExpanded = true; + this.treeView.SelectItems(new ITreeNodeData[] { node }); + this.treeView.Focus(); + } + + public void OnActivated(IAnalyzerTreeNodeData node) { + if (node == null) + throw new ArgumentNullException(); + bool newTab = Keyboard.Modifiers == ModifierKeys.Control || Keyboard.Modifiers == ModifierKeys.Shift; + FollowNode(node, newTab, null); + } + + public void FollowNode(ITreeNodeData node, bool newTab, bool? useCodeRef) { + var tokNode = node as IMDTokenNode; + var @ref = tokNode == null ? null : tokNode.Reference; + + var entityNode = node as EntityNode; + var srcRef = entityNode == null ? null : entityNode.SourceRef; + + bool code = useCodeRef ?? srcRef != null; + if (code) { + if (srcRef == null) + return; + fileTabManager.FollowReference(srcRef.Value.Method, newTab, true, a => { + if (!a.HasMovedCaret && a.Success && srcRef != null) + a.HasMovedCaret = GoTo(a.Tab, srcRef.Value.Method, srcRef.Value.ILOffset, srcRef.Value.Reference); + }); + } + else { + if (@ref == null) + return; + fileTabManager.FollowReference(@ref, newTab); + } + } + + public bool CanFollowNode(ITreeNodeData node, bool useCodeRef) { + var tokNode = node as IMDTokenNode; + var @ref = tokNode == null ? null : tokNode.Reference; + + var entityNode = node as EntityNode; + var srcRef = entityNode == null ? null : entityNode.SourceRef; + + if (useCodeRef) + return srcRef != null; + return @ref != null; + } + + bool GoTo(IFileTab tab, MethodDef method, uint? ilOffset, object @ref) { + if (method == null || ilOffset == null) + return false; + var uiContext = tab.TryGetTextEditorUIContext(); + if (uiContext == null) + return false; + var cm = uiContext.GetCodeMappings(); + var mapping = cm.Find(method, ilOffset.Value); + if (mapping == null) + return false; + + var location = mapping.StartPosition; + var loc = FindLocation(uiContext.GetCodeReferences(location.Line, location.Column), mapping.EndPosition, @ref); + if (loc == null) + loc = new TextEditorLocation(location.Line, location.Column); + + uiContext.ScrollAndMoveCaretTo(loc.Value.Line, loc.Value.Column); + return true; + } + + TextEditorLocation? FindLocation(IEnumerable> infos, TextPosition endLoc, object @ref) { + foreach (var info in infos) { + int c = Compare(info.Item2, endLoc); + if (c > 0) + break; + if (RefEquals(@ref, info.Item1.Reference)) + return info.Item2; + } + return null; + } + + static int Compare(TextEditorLocation a, TextPosition b) { + if (a.Line > b.Line) + return 1; + if (a.Line == b.Line) + return a.Column.CompareTo(b.Column); + return -1; + } + + static bool RefEquals(object a, object b) { + if (Equals(a, b)) + return true; + if (ReferenceEquals(a, null) || ReferenceEquals(b, null)) + return false; + + { + var pb = b as PropertyDef; + if (pb != null) { + var tmp = a; + a = b; + b = tmp; + } + var eb = b as EventDef; + if (eb != null) { + var tmp = a; + a = b; + b = tmp; + } + } + + const SigComparerOptions flags = SigComparerOptions.CompareDeclaringTypes | SigComparerOptions.PrivateScopeIsComparable; + + var type = a as IType; + if (type != null) + return new SigComparer().Equals(type, b as IType); + + var method = a as IMethod; + if (method != null && method.IsMethod) + return new SigComparer(flags).Equals(method, b as IMethod); + + var field = a as IField; + if (field != null && field.IsField) + return new SigComparer(flags).Equals(field, b as IField); + + var prop = a as PropertyDef; + if (prop != null) { + if (new SigComparer(flags).Equals(prop, b as PropertyDef)) + return true; + var bm = b as IMethod; + return bm != null && + (new SigComparer(flags).Equals(prop.GetMethod, bm) || + new SigComparer(flags).Equals(prop.SetMethod, bm)); + } + + var evt = a as EventDef; + if (evt != null) { + if (new SigComparer(flags).Equals(evt, b as EventDef)) + return true; + var bm = b as IMethod; + return bm != null && + (new SigComparer(flags).Equals(evt.AddMethod, bm) || + new SigComparer(flags).Equals(evt.InvokeMethod, bm) || + new SigComparer(flags).Equals(evt.RemoveMethod, bm)); + } + + Debug.Fail("Shouldn't be here"); + return false; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/AnalyzerSettings.cs b/Plugins/dnSpy.Analyzer/AnalyzerSettings.cs new file mode 100644 index 000000000..ee457cf29 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/AnalyzerSettings.cs @@ -0,0 +1,129 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.ComponentModel; +using System.ComponentModel.Composition; +using dnSpy.Contracts.Settings; +using dnSpy.Shared.MVVM; + +namespace dnSpy.Analyzer { + interface IAnalyzerSettings : INotifyPropertyChanged { + bool SyntaxHighlight { get; } + bool ShowToken { get; } + bool SingleClickExpandsChildren { get; } + bool UseNewRenderer { get; } + } + + class AnalyzerSettings : ViewModelBase, IAnalyzerSettings { + protected virtual void OnModified() { + } + + public bool SyntaxHighlight { + get { return syntaxHighlight; } + set { + if (syntaxHighlight != value) { + syntaxHighlight = value; + OnPropertyChanged("SyntaxHighlight"); + OnModified(); + } + } + } + bool syntaxHighlight = true; + + public bool ShowToken { + get { return showToken; } + set { + if (showToken != value) { + showToken = value; + OnPropertyChanged("ShowToken"); + OnModified(); + } + } + } + bool showToken = true; + + public bool SingleClickExpandsChildren { + get { return singleClickExpandsChildren; } + set { + if (singleClickExpandsChildren != value) { + singleClickExpandsChildren = value; + OnPropertyChanged("SingleClickExpandsChildren"); + OnModified(); + } + } + } + bool singleClickExpandsChildren = true; + + public bool UseNewRenderer { + get { return useNewRenderer; } + set { + if (useNewRenderer != value) { + useNewRenderer = value; + OnPropertyChanged("UseNewRenderer"); + OnModified(); + } + } + } + bool useNewRenderer = false; + + public AnalyzerSettings Clone() { + return CopyTo(new AnalyzerSettings()); + } + + public AnalyzerSettings CopyTo(AnalyzerSettings other) { + other.SyntaxHighlight = this.SyntaxHighlight; + other.ShowToken = this.ShowToken; + other.SingleClickExpandsChildren = this.SingleClickExpandsChildren; + other.UseNewRenderer = this.UseNewRenderer; + return other; + } + } + + [Export, Export(typeof(IAnalyzerSettings)), PartCreationPolicy(CreationPolicy.Shared)] + sealed class AnalyzerSettingsImpl : AnalyzerSettings { + static readonly Guid SETTINGS_GUID = new Guid("0A9208EC-CFAB-41C2-82C6-FCDA44A8E684"); + + readonly ISettingsManager settingsManager; + + [ImportingConstructor] + AnalyzerSettingsImpl(ISettingsManager settingsManager) { + this.settingsManager = settingsManager; + + this.disableSave = true; + var sect = settingsManager.GetOrCreateSection(SETTINGS_GUID); + this.SyntaxHighlight = sect.Attribute("SyntaxHighlight") ?? this.SyntaxHighlight; + this.ShowToken = sect.Attribute("ShowToken") ?? this.ShowToken; + this.SingleClickExpandsChildren = sect.Attribute("SingleClickExpandsChildren") ?? this.SingleClickExpandsChildren; + this.UseNewRenderer = sect.Attribute("UseNewRenderer") ?? this.UseNewRenderer; + this.disableSave = false; + } + readonly bool disableSave; + + protected override void OnModified() { + if (disableSave) + return; + var sect = settingsManager.RecreateSection(SETTINGS_GUID); + sect.Attribute("SyntaxHighlight", SyntaxHighlight); + sect.Attribute("ShowToken", ShowToken); + sect.Attribute("SingleClickExpandsChildren", SingleClickExpandsChildren); + sect.Attribute("UseNewRenderer", UseNewRenderer); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/AnalyzerToolWindowContent.cs b/Plugins/dnSpy.Analyzer/AnalyzerToolWindowContent.cs new file mode 100644 index 000000000..f6dc224a3 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/AnalyzerToolWindowContent.cs @@ -0,0 +1,102 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections.Generic; +using System.ComponentModel.Composition; +using System.Windows; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Controls; +using dnSpy.Contracts.ToolWindows; +using dnSpy.Contracts.ToolWindows.App; + +namespace dnSpy.Analyzer { + [Export(typeof(IMainToolWindowContentCreator))] + sealed class AnalyzerToolWindowContentCreator : IMainToolWindowContentCreator { + readonly Lazy analyzerManager; + + public AnalyzerToolWindowContent FileTreeViewWindowContent { + get { return analyzerToolWindowContent ?? (analyzerToolWindowContent = new AnalyzerToolWindowContent(analyzerManager)); } + } + AnalyzerToolWindowContent analyzerToolWindowContent; + + [ImportingConstructor] + AnalyzerToolWindowContentCreator(Lazy analyzerManager) { + this.analyzerManager = analyzerManager; + } + + public IEnumerable ContentInfos { + get { yield return new ToolWindowContentInfo(AnalyzerToolWindowContent.THE_GUID, AnalyzerToolWindowContent.DEFAULT_LOCATION, AppToolWindowConstants.DEFAULT_CONTENT_ORDER_BOTTOM_ANALYZER, false); } + } + + public IToolWindowContent GetOrCreate(Guid guid) { + if (guid == AnalyzerToolWindowContent.THE_GUID) + return FileTreeViewWindowContent; + return null; + } + } + + sealed class AnalyzerToolWindowContent : IToolWindowContent, IFocusable { + public static readonly Guid THE_GUID = new Guid("5827D693-A5DF-4D65-B1F8-ACF249508A96"); + public const AppToolWindowLocation DEFAULT_LOCATION = AppToolWindowLocation.DefaultHorizontal; + + public IInputElement FocusedElement { + get { return null; } + } + + public FrameworkElement ScaleElement { + get { return analyzerManager.Value.TreeView.UIObject as FrameworkElement; } + } + + public Guid Guid { + get { return THE_GUID; } + } + + public string Title { + get { return dnSpy_Analyzer_Resources.AnalyzerWindowTitle; } + } + + public object ToolTip { + get { return null; } + } + + public object UIObject { + get { return analyzerManager.Value.TreeView.UIObject; } + } + + public bool CanFocus { + get { return true; } + } + + readonly Lazy analyzerManager; + + public AnalyzerToolWindowContent(Lazy analyzerManager) { + this.analyzerManager = analyzerManager; + } + + public void OnVisibilityChanged(ToolWindowContentVisibilityEvent visEvent) { + if (visEvent == ToolWindowContentVisibilityEvent.Removed) + analyzerManager.Value.OnClose(); + } + + public void Focus() { + analyzerManager.Value.TreeView.Focus(); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/AnalyzerTreeNodeDataContext.cs b/Plugins/dnSpy.Analyzer/AnalyzerTreeNodeDataContext.cs new file mode 100644 index 000000000..ee524b996 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/AnalyzerTreeNodeDataContext.cs @@ -0,0 +1,36 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using dnSpy.Analyzer.TreeNodes; +using dnSpy.Contracts.Files; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; + +namespace dnSpy.Analyzer { + sealed class AnalyzerTreeNodeDataContext : IAnalyzerTreeNodeDataContext { + public IDotNetImageManager DotNetImageManager { get; set; } + public ILanguage Language { get; set; } + public IFileManager FileManager { get; set; } + public IAnalyzerManager AnalyzerManager { get; set; } + public bool ShowToken { get; set; } + public bool SingleClickExpandsChildren { get; set; } + public bool SyntaxHighlight { get; set; } + public bool UseNewRenderer { get; set; } + } +} diff --git a/Plugins/dnSpy.Analyzer/Commands.cs b/Plugins/dnSpy.Analyzer/Commands.cs new file mode 100644 index 000000000..a6a3a4af9 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/Commands.cs @@ -0,0 +1,234 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections.Generic; +using System.ComponentModel.Composition; +using System.Runtime.InteropServices; +using System.Text; +using System.Windows; +using System.Windows.Input; +using dnSpy.Contracts.Controls; +using dnSpy.Contracts.Menus; +using dnSpy.Contracts.Plugin; +using dnSpy.Contracts.TreeView; +using dnSpy.Shared.Menus; + +namespace dnSpy.Analyzer { + abstract class OpenReferenceCtxMenuCommandBase : MenuItemBase { + readonly Lazy analyzerManager; + readonly bool newTab; + readonly bool useCodeRef; + + protected OpenReferenceCtxMenuCommandBase(Lazy analyzerManager, bool newTab, bool useCodeRef) { + this.analyzerManager = analyzerManager; + this.newTab = newTab; + this.useCodeRef = useCodeRef; + } + + public override void Execute(IMenuItemContext context) { + var @ref = GetReference(context); + if (@ref == null) + return; + analyzerManager.Value.FollowNode(@ref, newTab, useCodeRef); + } + + public override bool IsVisible(IMenuItemContext context) { + return GetReference(context) != null; + } + + ITreeNodeData GetReference(IMenuItemContext context) { + if (context.CreatorObject.Guid != new Guid(MenuConstants.GUIDOBJ_ANALYZER_TREEVIEW_GUID)) + return null; + + var nodes = context.Find(); + if (nodes == null || nodes.Length != 1) + return null; + + var tokenNode = nodes[0] as IMDTokenNode; + if (tokenNode != null && tokenNode.Reference != null) { + if (!analyzerManager.Value.CanFollowNode(nodes[0], useCodeRef)) + return null; + return nodes[0]; + } + + return null; + } + } + + [ExportMenuItem(Header = "res:GoToReferenceInCodeCommand", InputGestureText = "res:DoubleClick", Group = MenuConstants.GROUP_CTX_ANALYZER_TABS, Order = 0)] + sealed class OpenReferenceInCodeCtxMenuCommand : OpenReferenceCtxMenuCommandBase { + [ImportingConstructor] + OpenReferenceInCodeCtxMenuCommand(Lazy analyzerManager) + : base(analyzerManager, false, true) { + } + } + + [ExportMenuItem(Header = "res:GoToReferenceInCodeNewTabCommand", InputGestureText = "res:ShiftDoubleClick", Group = MenuConstants.GROUP_CTX_ANALYZER_TABS, Order = 10)] + sealed class OpenReferenceInCodeNewTabCtxMenuCommand : OpenReferenceCtxMenuCommandBase { + [ImportingConstructor] + OpenReferenceInCodeNewTabCtxMenuCommand(Lazy analyzerManager) + : base(analyzerManager, true, true) { + } + } + + [ExportMenuItem(Header = "res:GoToReferenceCommand", Group = MenuConstants.GROUP_CTX_ANALYZER_TABS, Order = 20)] + sealed class OpenReferenceCtxMenuCommand : OpenReferenceCtxMenuCommandBase { + [ImportingConstructor] + OpenReferenceCtxMenuCommand(Lazy analyzerManager) + : base(analyzerManager, false, false) { + } + } + + [ExportMenuItem(Header = "res:GoToReferenceNewTabCommand", Group = MenuConstants.GROUP_CTX_ANALYZER_TABS, Order = 30)] + sealed class OpenReferenceNewTabCtxMenuCommand : OpenReferenceCtxMenuCommandBase { + [ImportingConstructor] + OpenReferenceNewTabCtxMenuCommand(Lazy analyzerManager) + : base(analyzerManager, true, false) { + } + } + + [ExportAutoLoaded] + sealed class BreakpointsContentCommandLoader : IAutoLoaded { + [ImportingConstructor] + BreakpointsContentCommandLoader(IWpfCommandManager wpfCommandManager, Lazy analyzerManager) { + var cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_ANALYZER_TREEVIEW); + cmds.Add(ApplicationCommands.Copy, + (s, e) => CopyCtxMenuCommand.ExecuteInternal(analyzerManager), + (s, e) => e.CanExecute = CopyCtxMenuCommand.CanExecuteInternal(analyzerManager)); + } + } + + [ExportMenuItem(Header = "res:CopyCommand", InputGestureText = "res:ShortCutKeyCtrlC", Icon = "Copy", Group = MenuConstants.GROUP_CTX_ANALYZER_TOKENS, Order = -1)] + sealed class CopyCtxMenuCommand : MenuItemBase { + readonly Lazy analyzerManager; + + [ImportingConstructor] + CopyCtxMenuCommand(Lazy analyzerManager) { + this.analyzerManager = analyzerManager; + } + + public override bool IsVisible(IMenuItemContext context) { + return context.CreatorObject.Guid == new Guid(MenuConstants.GUIDOBJ_ANALYZER_TREEVIEW_GUID); + } + + public override bool IsEnabled(IMenuItemContext context) { + return CanExecuteInternal(analyzerManager); + } + + public override void Execute(IMenuItemContext context) { + ExecuteInternal(analyzerManager); + } + + public static bool CanExecuteInternal(Lazy analyzerManager) { + return analyzerManager.Value.TreeView.SelectedItems.Length > 0; + } + + public static void ExecuteInternal(Lazy analyzerManager) { + var items = analyzerManager.Value.TreeView.SelectedItems; + var sb = new StringBuilder(); + int count = 0; + foreach (var t in GetNodes(analyzerManager.Value.TreeView, items)) { + if (count > 0) + sb.Append(Environment.NewLine); + sb.Append(new string('\t', t.Item1)); + sb.Append(t.Item2.ToString()); + count++; + } + if (count > 1) + sb.Append(Environment.NewLine); + if (sb.Length > 0) { + try { + Clipboard.SetText(sb.ToString()); + } + catch (ExternalException) { } + } + } + + sealed class State { + public readonly int Level; + public int Index; + public readonly IList Nodes; + public State(ITreeNode node, int level) { + this.Level = level; + this.Nodes = node.Children; + } + } + + static IEnumerable> GetNodes(ITreeView treeView, IEnumerable nodes) { + var hash = new HashSet(nodes); + var stack = new Stack(); + stack.Push(new State(treeView.Root, 0)); + while (stack.Count > 0) { + var state = stack.Pop(); + if (state.Index >= state.Nodes.Count) + continue; + var child = state.Nodes[state.Index++]; + if (hash.Contains(child.Data)) + yield return Tuple.Create(state.Level, child.Data); + stack.Push(state); + stack.Push(new State(child, state.Level + 1)); + } + } + } + + [ExportMenuItem(Header = "res:ShowMetadataTokensCommand", Group = MenuConstants.GROUP_CTX_ANALYZER_OPTIONS, Order = 0)] + sealed class ShowTokensCtxMenuCommand : MenuItemBase { + readonly AnalyzerSettingsImpl analyzerSettings; + + [ImportingConstructor] + ShowTokensCtxMenuCommand(AnalyzerSettingsImpl analyzerSettings) { + this.analyzerSettings = analyzerSettings; + } + + public override bool IsVisible(IMenuItemContext context) { + return context.CreatorObject.Guid == new Guid(MenuConstants.GUIDOBJ_ANALYZER_TREEVIEW_GUID); + } + + public override bool IsChecked(IMenuItemContext context) { + return analyzerSettings.ShowToken; + } + + public override void Execute(IMenuItemContext context) { + analyzerSettings.ShowToken = !analyzerSettings.ShowToken; + } + } + + [ExportMenuItem(Header = "res:SyntaxHighlightCommand", Group = MenuConstants.GROUP_CTX_ANALYZER_OPTIONS, Order = 10)] + sealed class SyntaxHighlightCtxMenuCommand : MenuItemBase { + readonly AnalyzerSettingsImpl analyzerSettings; + + [ImportingConstructor] + SyntaxHighlightCtxMenuCommand(AnalyzerSettingsImpl analyzerSettings) { + this.analyzerSettings = analyzerSettings; + } + + public override bool IsVisible(IMenuItemContext context) { + return context.CreatorObject.Guid == new Guid(MenuConstants.GUIDOBJ_ANALYZER_TREEVIEW_GUID); + } + + public override bool IsChecked(IMenuItemContext context) { + return analyzerSettings.SyntaxHighlight; + } + + public override void Execute(IMenuItemContext context) { + analyzerSettings.SyntaxHighlight = !analyzerSettings.SyntaxHighlight; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/Images/Copy.png b/Plugins/dnSpy.Analyzer/Images/Copy.png new file mode 100644 index 0000000000000000000000000000000000000000..8ff40a0fc6f034170439f61e6c725774e681c781 GIT binary patch literal 194 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`oCO|{#S9F5M?jcysy3fAP_V?) z#WAEJ?&yV$Tnz?1EEl>{GWW0T{x$d2qc})wc@2-deMg_KyHJkORhR`Tc4& z&Y#b7z!ZRKvgGYVny*{W5LuE6Q#KX=eYabj9 z5HV&q_n1gkLohi zm6`EA4%5IqFwAXAw`%*Uj~kUzy~*Gz6h)#DTnTs97)b{Xwe0i=YH20{)~qE%4W3l; zA4E`t3UGcfqO*)FX`*5@jCh|(VMM>fCTKQho%|4!ksJP6jDX85egj#fKn(R^jJp5; N002ovPDHLkV1g=X*X95K literal 0 HcmV?d00001 diff --git a/Plugins/dnSpy.Analyzer/Images/Search.png b/Plugins/dnSpy.Analyzer/Images/Search.png new file mode 100644 index 0000000000000000000000000000000000000000..042a1c4213de967aaca10a1d0fbc4598d95e3f6d GIT binary patch literal 522 zcmV+l0`>igP);SkDtGL z`2PQM&p84LMx&9JWtYC7%ap*O`}DQP<2eNpitrN4VXxN<<@0&WlF4KckH;NN)8cG$ zBqZTEmM@)7=TWItLeVH97z}~|oS$D{=haIPG#ZUFuC2-%=#JxjOsCVR*Xr~zL!5|2P5SOwB{X(I@EgnEczyAZ_a2Vv9<~qP_7Txdn!?G+`UoFWM|AJ98uFil;WW61Y1*kCWqL?CtL%o6RB;i8KK`5x0fQqGh&glkjX z%+c?|;c!(ld6O^g2*fl^DB+YvdeUyUuT6GMQzHI1VKM1F`D8VJ0p9r2D4Zy%4FCWD M07*qoM6N<$f(-ZZUH||9 literal 0 HcmV?d00001 diff --git a/Plugins/dnSpy.Analyzer/Plugin.cs b/Plugins/dnSpy.Analyzer/Plugin.cs new file mode 100644 index 000000000..4cf65501d --- /dev/null +++ b/Plugins/dnSpy.Analyzer/Plugin.cs @@ -0,0 +1,47 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System.Collections.Generic; +using System.ComponentModel.Composition; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Plugin; + +namespace dnSpy.Analyzer { + [ExportPlugin] + sealed class Plugin : IPlugin { + [ImportingConstructor] + Plugin() { + } + + public IEnumerable MergedResourceDictionaries { + get { yield break; } + } + + public PluginInfo PluginInfo { + get { + return new PluginInfo { + ShortDescription = dnSpy_Analyzer_Resources.Plugin_ShortDescription, + }; + } + } + + public void OnEvent(PluginEvent @event, object obj) { + } + } +} diff --git a/Plugins/dnSpy.Analyzer/Properties/AssemblyInfo.cs b/Plugins/dnSpy.Analyzer/Properties/AssemblyInfo.cs new file mode 100644 index 000000000..c9d83c13d --- /dev/null +++ b/Plugins/dnSpy.Analyzer/Properties/AssemblyInfo.cs @@ -0,0 +1,14 @@ +using System.Reflection; +using System.Resources; +using System.Runtime.InteropServices; + +[assembly: AssemblyTitle("Analyzer")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("Analyzer")] +[assembly: AssemblyCopyright("Copyright 2011-2014 AlphaSierraPapa for the SharpDevelop Team")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] +[assembly: ComVisible(false)] +[assembly: NeutralResourcesLanguage("en")] diff --git a/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.Designer.cs b/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.Designer.cs new file mode 100644 index 000000000..61959436b --- /dev/null +++ b/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.Designer.cs @@ -0,0 +1,360 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace dnSpy.Analyzer.Properties { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + public class dnSpy_Analyzer_Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal dnSpy_Analyzer_Resources() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + public static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("dnSpy.Analyzer.Properties.dnSpy.Analyzer.Resources", typeof(dnSpy_Analyzer_Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + public static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + + /// + /// Looks up a localized string similar to Analy_ze. + /// + public static string AnalyzeCommand { + get { + return ResourceManager.GetString("AnalyzeCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Analyzer. + /// + public static string AnalyzerWindowTitle { + get { + return ResourceManager.GetString("AnalyzerWindowTitle", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Applied To. + /// + public static string AppliedToTreeNode { + get { + return ResourceManager.GetString("AppliedToTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Assigned By. + /// + public static string AssignedByTreeNode { + get { + return ResourceManager.GetString("AssignedByTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Cop_y. + /// + public static string CopyCommand { + get { + return ResourceManager.GetString("CopyCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Dbl Click. + /// + public static string DoubleClick { + get { + return ResourceManager.GetString("DoubleClick", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to add. + /// + public static string EventAdderTreeNodeName { + get { + return ResourceManager.GetString("EventAdderTreeNodeName", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to remove. + /// + public static string EventRemoverTreeNodeName { + get { + return ResourceManager.GetString("EventRemoverTreeNodeName", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Exposed By. + /// + public static string ExposedByTreeNode { + get { + return ResourceManager.GetString("ExposedByTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Extension Methods. + /// + public static string ExtensionMethodsTreeNode { + get { + return ResourceManager.GetString("ExtensionMethodsTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Go to Reference. + /// + public static string GoToReferenceCommand { + get { + return ResourceManager.GetString("GoToReferenceCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Show Reference in Method. + /// + public static string GoToReferenceInCodeCommand { + get { + return ResourceManager.GetString("GoToReferenceInCodeCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Show Reference in Method (New _Tab). + /// + public static string GoToReferenceInCodeNewTabCommand { + get { + return ResourceManager.GetString("GoToReferenceInCodeNewTabCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Go to Reference (New Ta_b). + /// + public static string GoToReferenceNewTabCommand { + get { + return ResourceManager.GetString("GoToReferenceNewTabCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to hides. + /// + public static string HidesParent { + get { + return ResourceManager.GetString("HidesParent", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Implemented By. + /// + public static string ImplementedByTreeNode { + get { + return ResourceManager.GetString("ImplementedByTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Instantiated By. + /// + public static string InstantiatedByTreeNode { + get { + return ResourceManager.GetString("InstantiatedByTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Overridden By. + /// + public static string OverriddenByTreeNode { + get { + return ResourceManager.GetString("OverriddenByTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Analyzes assemblies. + /// + public static string Plugin_ShortDescription { + get { + return ResourceManager.GetString("Plugin_ShortDescription", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to get. + /// + public static string PropertyGetterTreeNode { + get { + return ResourceManager.GetString("PropertyGetterTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to set. + /// + public static string PropertySetterTreeNode { + get { + return ResourceManager.GetString("PropertySetterTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Raised By. + /// + public static string RaisedByTreeNode { + get { + return ResourceManager.GetString("RaisedByTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Read By. + /// + public static string ReadByTreeNode { + get { + return ResourceManager.GetString("ReadByTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to _Remove. + /// + public static string RemoveCommand { + get { + return ResourceManager.GetString("RemoveCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Searching.... + /// + public static string Searching { + get { + return ResourceManager.GetString("Searching", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Shift+Dbl Click. + /// + public static string ShiftDoubleClick { + get { + return ResourceManager.GetString("ShiftDoubleClick", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Ctrl+C. + /// + public static string ShortCutKeyCtrlC { + get { + return ResourceManager.GetString("ShortCutKeyCtrlC", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Ctrl+R. + /// + public static string ShortCutKeyCtrlR { + get { + return ResourceManager.GetString("ShortCutKeyCtrlR", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Del. + /// + public static string ShortCutKeyDelete { + get { + return ResourceManager.GetString("ShortCutKeyDelete", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Show Tokens. + /// + public static string ShowMetadataTokensCommand { + get { + return ResourceManager.GetString("ShowMetadataTokensCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Syntax Highlight. + /// + public static string SyntaxHighlightCommand { + get { + return ResourceManager.GetString("SyntaxHighlightCommand", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Used By. + /// + public static string UsedByTreeNode { + get { + return ResourceManager.GetString("UsedByTreeNode", resourceCulture); + } + } + + /// + /// Looks up a localized string similar to Uses. + /// + public static string UsesTreeNode { + get { + return ResourceManager.GetString("UsesTreeNode", resourceCulture); + } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.resx b/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.resx new file mode 100644 index 000000000..f2a3ecf86 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.resx @@ -0,0 +1,219 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Analy_ze + + + Analyzer + + + Applied To + + + Assigned By + + + Cop_y + + + Dbl Click + + + add + + + remove + + + Exposed By + + + Extension Methods + + + Go to Reference + + + Show Reference in Method + + + Show Reference in Method (New _Tab) + + + Go to Reference (New Ta_b) + + + hides + + + Implemented By + + + Instantiated By + + + Overridden By + + + Analyzes assemblies + + + get + + + set + + + Raised By + + + Read By + + + _Remove + + + Searching... + + + Shift+Dbl Click + + + Ctrl+C + + + Ctrl+R + + + Del + + + Show Tokens + + + Syntax Highlight + + + Used By + + + Uses + + \ No newline at end of file diff --git a/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.ru.resx b/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.ru.resx new file mode 100644 index 000000000..c4f4846a1 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.ru.resx @@ -0,0 +1,219 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Анали_зировать + + + Анализатор + + + Применяется к + + + Кем назначено + + + Коп_ировать + + + Dbl Click + + + add + + + remove + + + Кем представлено + + + Методы расширения + + + Перейти по ссылке + + + Показать ссылку на метод + + + Показать ссылку в методе (новая _вкладка) + + + Перейти к ссылке (New Ta_b) + + + hides + + + Реализовано в + + + Вызвано в + + + Перегружен в + + + Анализирует сборки + + + get + + + set + + + Кем вызвано + + + Кем читается + + + _Убрать + + + Поиск... + + + Shift+Dbl Click + + + Ctrl+C + + + Ctrl+R + + + Del + + + Показать токены + + + Подсветка синтаксиса + + + Используется + + + Использует + + diff --git a/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.zh-CN.resx b/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.zh-CN.resx new file mode 100644 index 000000000..a41bfc47b --- /dev/null +++ b/Plugins/dnSpy.Analyzer/Properties/dnSpy.Analyzer.Resources.zh-CN.resx @@ -0,0 +1,219 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + 分析(_Z) + + + 分析器 + + + 已应用到 + + + 被赋值 + + + 复制(_Y) + + + 双击 + + + 添加 + + + 移除 + + + 被公开 + + + 扩展方法 + + + 转到引用 + + + 显示方法内的引用 + + + 显示方法内引用(新标签) + + + 转到引用(新标签)(_B) + + + 隐藏 + + + 被实现 + + + 被实例化 + + + 被重写 + + + 分析程序集 + + + get + + + set + + + 被触发 + + + 被读取 + + + 移除(_R) + + + 搜索中… + + + Shift+双击 + + + Ctrl+C + + + Ctrl+R + + + Del + + + 显示Tokens + + + 语法高亮 + + + 被使用 + + + 使用 + + diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/AnalyzerTreeNodeData.cs b/Plugins/dnSpy.Analyzer/TreeNodes/AnalyzerTreeNodeData.cs new file mode 100644 index 000000000..79404aab7 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/AnalyzerTreeNodeData.cs @@ -0,0 +1,162 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Linq; +using dnlib.DotNet; +using dnSpy.Contracts.Files; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.TreeView; +using dnSpy.Shared.Highlighting; +using dnSpy.Shared.TreeView; + +namespace dnSpy.Analyzer.TreeNodes { + abstract class AnalyzerTreeNodeData : TreeNodeData, IAnalyzerTreeNodeData { + public override Guid Guid { + get { return Guid.Empty; } + } + + public sealed override bool SingleClickExpandsChildren { + get { return Context.SingleClickExpandsChildren; } + } + + public IAnalyzerTreeNodeDataContext Context { get; set; } + + protected abstract ImageReference GetIcon(IDotNetImageManager dnImgMgr); + protected virtual ImageReference? GetExpandedIcon(IDotNetImageManager dnImgMgr) { + return null; + } + + public sealed override ImageReference Icon { + get { return GetIcon(this.Context.DotNetImageManager); } + } + + public sealed override ImageReference? ExpandedIcon { + get { return GetExpandedIcon(this.Context.DotNetImageManager); } + } + + public sealed override object Text { + get { + var gen = UISyntaxHighlighter.Create(Context.SyntaxHighlight); + + var cached = cachedText != null ? cachedText.Target : null; + if (cached != null) + return cached; + + Write(gen.Output, Context.Language); + + var text = gen.CreateResultNewFormatter(Context.UseNewRenderer, filterOutNewLines: true); + cachedText = new WeakReference(text); + return text; + } + } + WeakReference cachedText; + + protected abstract void Write(ISyntaxHighlightOutput output, ILanguage language); + + public sealed override object ToolTip { + get { return null; } + } + + public sealed override string ToString() { + return ToString(Context.Language); + } + + public string ToString(ILanguage language) { + var output = new NoSyntaxHighlightOutput(); + Write(output, language); + return output.ToString(); + } + + public sealed override void OnRefreshUI() { + cachedText = null; + } + + public abstract bool HandleAssemblyListChanged(IDnSpyFile[] removedAssemblies, IDnSpyFile[] addedAssemblies); + public abstract bool HandleModelUpdated(IDnSpyFile[] files); + + public static void CancelSelfAndChildren(ITreeNodeData node) { + foreach (var c in node.DescendantsAndSelf()) { + var id = c as IAsyncCancellable; + if (id != null) + id.Cancel(); + } + } + + public static void HandleAssemblyListChanged(ITreeNode node, IDnSpyFile[] removedAssemblies, IDnSpyFile[] addedAssemblies) { + var children = node.DataChildren.ToArray(); + for (int i = children.Length - 1; i >= 0; i--) { + var c = children[i]; + var n = c as IAnalyzerTreeNodeData; + if (n == null || !n.HandleAssemblyListChanged(removedAssemblies, addedAssemblies)) { + AnalyzerTreeNodeData.CancelSelfAndChildren(c); + node.Children.RemoveAt(i); + } + } + } + + public static void HandleModelUpdated(ITreeNode node, IDnSpyFile[] files) { + var children = node.DataChildren.ToArray(); + for (int i = children.Length - 1; i >= 0; i--) { + var c = children[i]; + var n = c as IAnalyzerTreeNodeData; + if (n == null || !n.HandleModelUpdated(files)) { + AnalyzerTreeNodeData.CancelSelfAndChildren(c); + node.Children.RemoveAt(i); + } + } + } + + protected IMemberRef GetOriginalCodeLocation(IMemberRef member) { + // Emulate the original code. Only the C# override returned something other than the input + if (Context.Language.UniqueGuid != LanguageConstants.LANGUAGE_CSHARP_ILSPY) + return member; + if (!Context.Language.Settings.GetBoolean(DecompilerOptionConstants.AnonymousMethods_GUID)) + return member; + return Helpers.GetOriginalCodeLocation(member); + } + + sealed class TheTreeNodeGroup : ITreeNodeGroup { + public static ITreeNodeGroup Instance = new TheTreeNodeGroup(); + + TheTreeNodeGroup() { + } + + public double Order { + get { return 100; } + } + + public int Compare(ITreeNodeData x, ITreeNodeData y) { + if (x == y) + return 0; + var a = x as IAnalyzerTreeNodeData; + var b = y as IAnalyzerTreeNodeData; + if (a == null) return -1; + if (b == null) return 1; + return StringComparer.OrdinalIgnoreCase.Compare(a.ToString(), b.ToString()); + } + } + + public override ITreeNodeGroup TreeNodeGroup { + get { return TheTreeNodeGroup.Instance; } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/AssemblyNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/AssemblyNode.cs new file mode 100644 index 000000000..5a7077079 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/AssemblyNode.cs @@ -0,0 +1,49 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 dnlib.DotNet; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Shared.Highlighting; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class AssemblyNode : EntityNode { + readonly AssemblyDef analyzedAssembly; + + public AssemblyNode(AssemblyDef analyzedAssembly) { + this.analyzedAssembly = analyzedAssembly; + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return dnImgMgr.GetImageReference(analyzedAssembly); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(analyzedAssembly); + } + + public override IMemberRef Member { + get { return null; } + } + + public override IMDTokenProvider Reference { + get { return analyzedAssembly; } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/AsyncFetchChildrenHelper.cs b/Plugins/dnSpy.Analyzer/TreeNodes/AsyncFetchChildrenHelper.cs new file mode 100644 index 000000000..600859dfc --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/AsyncFetchChildrenHelper.cs @@ -0,0 +1,93 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Files.TreeView; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.TreeView; +using dnSpy.Shared.TreeView; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class AsyncFetchChildrenHelper : AsyncNodeCreator { + readonly SearchNode node; + readonly Action completed; + + public AsyncFetchChildrenHelper(SearchNode node, Action completed) + : base(node) { + this.node = node; + this.completed = completed; + Start(); + } + + sealed class MessageNodeTreeNodeGroup : ITreeNodeGroup { + public double Order { + get { return order; } + set { order = value; } + } + double order; + + public int Compare(ITreeNodeData x, ITreeNodeData y) { + if (x == y) + return 0; + var a = x as IMessageNode; + var b = y as IMessageNode; + if (a == null) return -1; + if (b == null) return 1; + return 0; + } + } + + sealed class MessageNode : TreeNodeData { + public override Guid Guid { + get { return Guid.Empty; } + } + + public override ImageReference Icon { + get { return new ImageReference(GetType().Assembly, "Search"); } + } + + public override object Text { + get { return dnSpy_Analyzer_Resources.Searching; } + } + + public override object ToolTip { + get { return null; } + } + + public override void OnRefreshUI() { + } + + public override ITreeNodeGroup TreeNodeGroup { + get { return treeNodeGroup; } + } + readonly ITreeNodeGroup treeNodeGroup = new MessageNodeTreeNodeGroup(); + } + + protected override void ThreadMethod() { + AddMessageNode(() => new MessageNode()); + foreach (var child in node.FetchChildrenInternal(cancellationToken)) + AddNode(child); + } + + protected override void OnCompleted() { + completed(); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/AttributeAppliedToNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/AttributeAppliedToNode.cs new file mode 100644 index 000000000..6679b4fcb --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/AttributeAppliedToNode.cs @@ -0,0 +1,366 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Concurrent; +using System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnlib.Threading; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class AttributeAppliedToNode : SearchNode { + readonly TypeDef analyzedType; + readonly string attributeName; + + AttributeTargets usage = AttributeTargets.All; + bool allowMutiple; + bool inherited = true; + ConcurrentDictionary foundMethods; + + public static bool CanShow(TypeDef type) { + return type.IsClass && IsCustomAttribute(type); + } + + static bool IsCustomAttribute(TypeDef type) { + while (type != null) { + var bt = type.BaseType.ResolveTypeDef(); + if (bt == null) + return false; + if (bt.FullName == "System.Attribute") + return true; + type = bt; + } + return false; + } + + public AttributeAppliedToNode(TypeDef analyzedType) { + if (analyzedType == null) + throw new ArgumentNullException("analyzedType"); + + this.analyzedType = analyzedType; + attributeName = this.analyzedType.FullName; + GetAttributeUsage(); + } + + void GetAttributeUsage() { + if (analyzedType.HasCustomAttributes) { + foreach (CustomAttribute ca in analyzedType.CustomAttributes) { + ITypeDefOrRef t = ca.AttributeType; + if (t != null && t.Name == "AttributeUsageAttribute" && t.Namespace == "System" && + ca.ConstructorArguments.Count > 0 && + ca.ConstructorArguments[0].Value is int) { + this.usage = (AttributeTargets)ca.ConstructorArguments[0].Value; + if (ca.ConstructorArguments.Count > 2) { + if (ca.ConstructorArguments[1].Value is bool) + this.allowMutiple = (bool)ca.ConstructorArguments[1].Value; + if (ca.ConstructorArguments[2].Value is bool) + this.inherited = (bool)ca.ConstructorArguments[2].Value; + } + foreach (var namedArgument in ca.Properties) { + switch (namedArgument.Name) { + case "AllowMultiple": + if (namedArgument.Argument.Value is bool) + this.allowMutiple = (bool)namedArgument.Argument.Value; + break; + case "Inherited": + if (namedArgument.Argument.Value is bool) + this.inherited = (bool)namedArgument.Argument.Value; + break; + } + } + } + } + } + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.AppliedToTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + foundMethods = new ConcurrentDictionary(); + + //get the assemblies to search + var currentAssembly = analyzedType.Module.Assembly; + var modules = analyzedType.IsPublic ? GetReferencingModules(analyzedType.Module, ct) : GetModuleAndAnyFriends(analyzedType.Module, ct); + + var results = modules.AsParallel().WithCancellation(ct).SelectMany(a => FindReferencesInModule(new[] { a.Item1 }, a.Item2, ct)); + + foreach (var result in results) + yield return result; + + foundMethods = null; + } + + IEnumerable FindReferencesInModule(IEnumerable modules, ITypeDefOrRef tr, CancellationToken ct) { + var checkedAsms = new HashSet(); + foreach (var module in modules) { + if ((usage & AttributeTargets.Assembly) != 0) { + AssemblyDef asm = module.Assembly; + if (asm != null && !checkedAsms.Contains(asm) && asm.HasCustomAttributes) { + checkedAsms.Add(asm); + foreach (var attribute in asm.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, tr)) { + yield return new AssemblyNode(asm) { Context = Context }; + break; + } + } + } + } + + ct.ThrowIfCancellationRequested(); + + if ((usage & AttributeTargets.Module) != 0) { + if (module.HasCustomAttributes) { + foreach (var attribute in module.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, tr)) { + yield return new ModuleNode(module) { Context = Context }; + break; + } + } + } + } + + ct.ThrowIfCancellationRequested(); + + foreach (TypeDef type in TreeTraversal.PreOrder(module.Types, t => t.NestedTypes)) { + ct.ThrowIfCancellationRequested(); + foreach (var result in FindReferencesWithinInType(type, tr)) { + ct.ThrowIfCancellationRequested(); + yield return result; + } + } + } + } + + IEnumerable FindReferencesWithinInType(TypeDef type, ITypeDefOrRef attrTypeRef) { + + bool searchRequired = (type.IsClass && usage.HasFlag(AttributeTargets.Class)) + || (type.IsEnum && usage.HasFlag(AttributeTargets.Enum)) + || (type.IsInterface && usage.HasFlag(AttributeTargets.Interface)) + || (type.IsValueType && usage.HasFlag(AttributeTargets.Struct)); + if (searchRequired) { + if (type.HasCustomAttributes) { + foreach (var attribute in type.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, attrTypeRef)) { + yield return new TypeNode(type) { Context = Context }; + break; + } + } + } + } + + if ((this.usage & AttributeTargets.GenericParameter) != 0 && type.HasGenericParameters) { + foreach (var parameter in type.GenericParameters) { + if (parameter.HasCustomAttributes) { + foreach (var attribute in parameter.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, attrTypeRef)) { + yield return new TypeNode(type) { Context = Context }; + break; + } + } + } + } + } + + if ((this.usage & AttributeTargets.Field) != 0 && type.HasFields) { + foreach (var field in type.Fields) { + if (field.HasCustomAttributes) { + foreach (var attribute in field.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, attrTypeRef)) { + yield return new FieldNode(field) { Context = Context }; + break; + } + } + } + } + } + + if (((usage & AttributeTargets.Property) != 0) && type.HasProperties) { + foreach (var property in type.Properties) { + if (property.HasCustomAttributes) { + foreach (var attribute in property.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, attrTypeRef)) { + yield return new PropertyNode(property) { Context = Context }; + break; + } + } + } + } + } + if (((usage & AttributeTargets.Event) != 0) && type.HasEvents) { + foreach (var _event in type.Events) { + if (_event.HasCustomAttributes) { + foreach (var attribute in _event.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, attrTypeRef)) { + yield return new EventNode(_event) { Context = Context }; + break; + } + } + } + } + } + + if (type.HasMethods) { + foreach (var method in type.Methods) { + bool found = false; + if ((usage & (AttributeTargets.Method | AttributeTargets.Constructor)) != 0) { + if (method.HasCustomAttributes) { + foreach (var attribute in method.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, attrTypeRef)) { + found = true; + break; + } + } + } + } + if (!found && + ((usage & AttributeTargets.ReturnValue) != 0) && + method.Parameters.ReturnParameter.HasParamDef && + method.Parameters.ReturnParameter.ParamDef.HasCustomAttributes) { + foreach (var attribute in method.Parameters.ReturnParameter.ParamDef.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, attrTypeRef)) { + found = true; + break; + } + } + } + + if (!found && + ((usage & AttributeTargets.Parameter) != 0) && + method.Parameters.Count > 0) { + foreach (var parameter in method.Parameters.Where(param => param.HasParamDef)) { + if (parameter.IsHiddenThisParameter) + continue; + foreach (var attribute in parameter.ParamDef.CustomAttributes) { + if (new SigComparer().Equals(attribute.AttributeType, attrTypeRef)) { + found = true; + break; + } + } + } + } + + if (found) { + MethodDef codeLocation = GetOriginalCodeLocation(method) as MethodDef; + if (codeLocation != null && !HasAlreadyBeenFound(codeLocation)) { + yield return new MethodNode(codeLocation) { Context = Context }; + } + } + } + } + } + + bool HasAlreadyBeenFound(MethodDef method) { + return !foundMethods.TryAdd(method, 0); + } + + IEnumerable> GetReferencingModules(ModuleDef mod, CancellationToken ct) { + var asm = mod.Assembly; + if (asm == null) { + yield return new Tuple(mod, this.analyzedType); + yield break; + } + + foreach (var m in asm.Modules.GetSafeEnumerable()) + yield return new Tuple(m, this.analyzedType); + + var assemblies = Context.FileManager.GetFiles().Where(a => a.AssemblyDef != null); + + foreach (var assembly in assemblies) { + ct.ThrowIfCancellationRequested(); + bool found = false; + foreach (var reference in assembly.AssemblyDef.Modules.GetSafeEnumerable().SelectMany(module => module.GetAssemblyRefs())) { + if (AssemblyNameComparer.CompareAll.CompareTo(asm, reference) == 0) { + found = true; + break; + } + } + if (found) { + var typeref = GetScopeTypeRefInAssembly(assembly.AssemblyDef); + if (typeref != null) { + foreach (var m in assembly.AssemblyDef.Modules.GetSafeEnumerable()) + yield return new Tuple(m, typeref); + } + } + } + } + + IEnumerable> GetModuleAndAnyFriends(ModuleDef mod, CancellationToken ct) { + var asm = mod.Assembly; + if (asm == null) { + yield return new Tuple(mod, this.analyzedType); + yield break; + } + + foreach (var m in asm.Modules.GetSafeEnumerable()) + yield return new Tuple(m, this.analyzedType); + + if (asm.HasCustomAttributes) { + var attributes = asm.CustomAttributes + .Where(attr => attr.TypeFullName == "System.Runtime.CompilerServices.InternalsVisibleToAttribute"); + var friendAssemblies = new HashSet(); + foreach (var attribute in attributes) { + if (attribute.ConstructorArguments.Count == 0) + continue; + string assemblyName = attribute.ConstructorArguments[0].Value as UTF8String; + if (assemblyName == null) + continue; + assemblyName = assemblyName.Split(',')[0]; // strip off any public key info + friendAssemblies.Add(assemblyName); + } + + if (friendAssemblies.Count > 0) { + var assemblies = Context.FileManager.GetFiles().Where(a => a.AssemblyDef != null); + + foreach (var assembly in assemblies) { + ct.ThrowIfCancellationRequested(); + if (friendAssemblies.Contains(assembly.AssemblyDef.Name)) { + var typeref = GetScopeTypeRefInAssembly(assembly.AssemblyDef); + if (typeref != null) { + foreach (var m in assembly.AssemblyDef.Modules.GetSafeEnumerable()) + yield return new Tuple(m, typeref); + } + } + } + } + } + } + + ITypeDefOrRef GetScopeTypeRefInAssembly(AssemblyDef asm) { + foreach (var mod in asm.Modules.GetSafeEnumerable()) { + foreach (var typeref in mod.GetTypeRefs()) { + if (new SigComparer().Equals(analyzedType, typeref)) + return typeref; + } + } + return null; + } + } + static class ExtensionMethods { + public static bool HasCustomAttribute(this IMemberRef member, string attributeTypeName) { + return false; + } + } +} \ No newline at end of file diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/Commands.cs b/Plugins/dnSpy.Analyzer/TreeNodes/Commands.cs new file mode 100644 index 000000000..2c206fd06 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/Commands.cs @@ -0,0 +1,391 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections.Generic; +using System.ComponentModel.Composition; +using System.Linq; +using System.Windows.Controls; +using System.Windows.Input; +using dnlib.DotNet; +using dnSpy.Contracts.Controls; +using dnSpy.Contracts.Files.Tabs; +using dnSpy.Contracts.Files.Tabs.TextEditor; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.Menus; +using dnSpy.Contracts.Plugin; +using dnSpy.Contracts.Search; +using dnSpy.Contracts.ToolWindows.App; +using dnSpy.Contracts.TreeView; +using dnSpy.Shared.Menus; + +namespace dnSpy.Analyzer.TreeNodes { + [ExportAutoLoaded] + sealed class AnalyzeCommandLoader : IAutoLoaded { + public static readonly RoutedCommand AnalyzeRoutedCommand = new RoutedCommand("AnalyzeRoutedCommand", typeof(AnalyzeCommandLoader)); + readonly IMainToolWindowManager mainToolWindowManager; + readonly IFileTabManager fileTabManager; + readonly Lazy analyzerManager; + readonly ILanguageManager languageManager; + + [ImportingConstructor] + AnalyzeCommandLoader(IMainToolWindowManager mainToolWindowManager, IWpfCommandManager wpfCommandManager, IFileTabManager fileTabManager, Lazy analyzerManager, ILanguageManager languageManager) { + this.mainToolWindowManager = mainToolWindowManager; + this.fileTabManager = fileTabManager; + this.analyzerManager = analyzerManager; + this.languageManager = languageManager; + + var cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_TEXTEDITOR_UICONTEXT); + cmds.Add(AnalyzeRoutedCommand, TextEditor_Executed, TextEditor_CanExecute, ModifierKeys.Control, Key.R); + cmds.Add(AnalyzeRoutedCommand, ShowAnalyzerExecuted, ShowAnalyzerCanExecute, ModifierKeys.Control, Key.R); + + cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_FILE_TREEVIEW); + cmds.Add(AnalyzeRoutedCommand, FileTreeView_Executed, FileTreeView_CanExecute, ModifierKeys.Control, Key.R); + cmds.Add(AnalyzeRoutedCommand, ShowAnalyzerExecuted, ShowAnalyzerCanExecute, ModifierKeys.Control, Key.R); + + cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_ANALYZER_TREEVIEW); + cmds.Add(AnalyzeRoutedCommand, AnalyzerTreeView_Executed, AnalyzerTreeView_CanExecute, ModifierKeys.Control, Key.R); + cmds.Add(AnalyzeRoutedCommand, ShowAnalyzerExecuted, ShowAnalyzerCanExecute, ModifierKeys.Control, Key.R); + + cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_SEARCH_LISTBOX); + cmds.Add(AnalyzeRoutedCommand, SearchListBox_Executed, SearchListBox_CanExecute, ModifierKeys.Control, Key.R); + cmds.Add(AnalyzeRoutedCommand, ShowAnalyzerExecuted, ShowAnalyzerCanExecute, ModifierKeys.Control, Key.R); + } + + void ShowAnalyzerCanExecute(object sender, CanExecuteRoutedEventArgs e) { + e.CanExecute = mainToolWindowManager.IsShown(AnalyzerToolWindowContent.THE_GUID); + } + + void ShowAnalyzerExecuted(object sender, ExecutedRoutedEventArgs e) { + mainToolWindowManager.Show(AnalyzerToolWindowContent.THE_GUID); + } + + void TextEditor_CanExecute(object sender, CanExecuteRoutedEventArgs e) { + e.CanExecute = AnalyzeCommand.CanAnalyze(TextEditor_GetMemberRef(), languageManager.Language); + } + + void TextEditor_Executed(object sender, ExecutedRoutedEventArgs e) { + AnalyzeCommand.Analyze(mainToolWindowManager, analyzerManager, languageManager.Language, TextEditor_GetMemberRef()); + } + + IMemberRef TextEditor_GetMemberRef() { + var tab = fileTabManager.ActiveTab; + var uiContext = tab == null ? null : tab.UIContext as ITextEditorUIContext; + if (uiContext == null) + return null; + return uiContext.SelectedReference as IMemberRef; + } + + void FileTreeView_CanExecute(object sender, CanExecuteRoutedEventArgs e) { + e.CanExecute = AnalyzeCommand.CanAnalyze(FileTreeView_GetMemberRef(), languageManager.Language); + } + + void FileTreeView_Executed(object sender, ExecutedRoutedEventArgs e) { + AnalyzeCommand.Analyze(mainToolWindowManager, analyzerManager, languageManager.Language, FileTreeView_GetMemberRef()); + } + + IMemberRef FileTreeView_GetMemberRef() { + var nodes = fileTabManager.FileTreeView.TreeView.TopLevelSelection; + var node = nodes.Length == 0 ? null : nodes[0] as IMDTokenNode; + return node == null ? null : node.Reference as IMemberRef; + } + + void AnalyzerTreeView_CanExecute(object sender, CanExecuteRoutedEventArgs e) { + e.CanExecute = AnalyzeCommand.CanAnalyze(AnalyzerTreeView_GetMemberRef(), languageManager.Language); + } + + void AnalyzerTreeView_Executed(object sender, ExecutedRoutedEventArgs e) { + AnalyzeCommand.Analyze(mainToolWindowManager, analyzerManager, languageManager.Language, AnalyzerTreeView_GetMemberRef()); + } + + IMemberRef AnalyzerTreeView_GetMemberRef() { + var nodes = analyzerManager.Value.TreeView.TopLevelSelection; + var node = nodes.Length == 0 ? null : nodes[0] as IMDTokenNode; + return node == null ? null : node.Reference as IMemberRef; + } + + void SearchListBox_CanExecute(object sender, CanExecuteRoutedEventArgs e) { + e.CanExecute = AnalyzeCommand.CanAnalyze(SearchListBox_GetMemberRef(e.Source as ListBox), languageManager.Language); + } + + void SearchListBox_Executed(object sender, ExecutedRoutedEventArgs e) { + AnalyzeCommand.Analyze(mainToolWindowManager, analyzerManager, languageManager.Language, SearchListBox_GetMemberRef(e.Source as ListBox)); + } + + IMemberRef SearchListBox_GetMemberRef(ListBox listBox) { + var sr = listBox == null ? null : listBox.SelectedItem as ISearchResult; + return sr == null ? null : sr.Reference as IMemberRef; + } + } + + static class AnalyzeCommand { + [ExportMenuItem(Header = "res:AnalyzeCommand", Icon = "Search", InputGestureText = "res:ShortCutKeyCtrlR", Group = MenuConstants.GROUP_CTX_FILES_OTHER, Order = 0)] + sealed class FilesCommand : MenuItemBase { + readonly IMainToolWindowManager mainToolWindowManager; + readonly ILanguageManager languageManager; + readonly Lazy analyzerManager; + + [ImportingConstructor] + FilesCommand(IMainToolWindowManager mainToolWindowManager, ILanguageManager languageManager, Lazy analyzerManager) { + this.mainToolWindowManager = mainToolWindowManager; + this.languageManager = languageManager; + this.analyzerManager = analyzerManager; + } + + public override bool IsVisible(IMenuItemContext context) { + return GetMemberRefs(context).Any(); + } + + IEnumerable GetMemberRefs(IMenuItemContext context) { + return GetMemberRefs(context, MenuConstants.GUIDOBJ_FILES_TREEVIEW_GUID, false, languageManager); + } + + internal static IEnumerable GetMemberRefs(IMenuItemContext context, string guid, bool checkRoot, ILanguageManager languageManager) { + if (context.CreatorObject.Guid != new Guid(guid)) + yield break; + var nodes = context.Find(); + if (nodes == null) + yield break; + + if (checkRoot && nodes.All(a => a.TreeNode.Parent != null && a.TreeNode.Parent.Parent == null)) + yield break; + + foreach (var node in nodes) { + var mr = node as IMDTokenNode; + if (mr != null && CanAnalyze(mr.Reference as IMemberRef, languageManager.Language)) + yield return mr.Reference as IMemberRef; + } + } + + public override void Execute(IMenuItemContext context) { + Analyze(mainToolWindowManager, analyzerManager, languageManager.Language, GetMemberRefs(context)); + } + } + + [ExportMenuItem(Header = "res:AnalyzeCommand", Icon = "Search", InputGestureText = "res:ShortCutKeyCtrlR", Group = MenuConstants.GROUP_CTX_ANALYZER_OTHER, Order = 0)] + sealed class AnalyzerCommand : MenuItemBase { + readonly IMainToolWindowManager mainToolWindowManager; + readonly ILanguageManager languageManager; + readonly Lazy analyzerManager; + + [ImportingConstructor] + AnalyzerCommand(IMainToolWindowManager mainToolWindowManager, ILanguageManager languageManager, Lazy analyzerManager) { + this.mainToolWindowManager = mainToolWindowManager; + this.languageManager = languageManager; + this.analyzerManager = analyzerManager; + } + + public override bool IsVisible(IMenuItemContext context) { + return GetMemberRefs(context).Any(); + } + + IEnumerable GetMemberRefs(IMenuItemContext context) { + return FilesCommand.GetMemberRefs(context, MenuConstants.GUIDOBJ_ANALYZER_TREEVIEW_GUID, true, languageManager); + } + + public override void Execute(IMenuItemContext context) { + Analyze(mainToolWindowManager, analyzerManager, languageManager.Language, GetMemberRefs(context)); + } + } + + [ExportMenuItem(Header = "res:AnalyzeCommand", Icon = "Search", InputGestureText = "res:ShortCutKeyCtrlR", Group = MenuConstants.GROUP_CTX_CODE_OTHER, Order = 0)] + sealed class CodeCommand : MenuItemBase { + readonly IMainToolWindowManager mainToolWindowManager; + readonly ILanguageManager languageManager; + readonly Lazy analyzerManager; + + [ImportingConstructor] + CodeCommand(IMainToolWindowManager mainToolWindowManager, ILanguageManager languageManager, Lazy analyzerManager) { + this.mainToolWindowManager = mainToolWindowManager; + this.languageManager = languageManager; + this.analyzerManager = analyzerManager; + } + + public override bool IsVisible(IMenuItemContext context) { + return GetMemberRefs(context).Any(); + } + + static IEnumerable GetMemberRefs(IMenuItemContext context) { + return GetMemberRefs(context, MenuConstants.GUIDOBJ_TEXTEDITORCONTROL_GUID); + } + + internal static IEnumerable GetMemberRefs(IMenuItemContext context, string guid) { + if (context.CreatorObject.Guid != new Guid(guid)) + yield break; + + var @ref = context.Find(); + if (@ref != null) { + var mr = @ref.Reference as IMemberRef; + if (mr != null) + yield return mr; + } + } + + public override void Execute(IMenuItemContext context) { + Analyze(mainToolWindowManager, analyzerManager, languageManager.Language, GetMemberRefs(context)); + } + } + + [ExportMenuItem(Header = "res:AnalyzeCommand", Icon = "Search", InputGestureText = "res:ShortCutKeyCtrlR", Group = MenuConstants.GROUP_CTX_SEARCH_OTHER, Order = 0)] + sealed class SearchCommand : MenuItemBase { + readonly IMainToolWindowManager mainToolWindowManager; + readonly ILanguageManager languageManager; + readonly Lazy analyzerManager; + + [ImportingConstructor] + SearchCommand(IMainToolWindowManager mainToolWindowManager, ILanguageManager languageManager, Lazy analyzerManager) { + this.mainToolWindowManager = mainToolWindowManager; + this.languageManager = languageManager; + this.analyzerManager = analyzerManager; + } + + static IEnumerable GetMemberRefs(IMenuItemContext context) { + return CodeCommand.GetMemberRefs(context, MenuConstants.GUIDOBJ_SEARCH_GUID); + } + + public override bool IsVisible(IMenuItemContext context) { + return GetMemberRefs(context).Any(); + } + + public override void Execute(IMenuItemContext context) { + Analyze(mainToolWindowManager, analyzerManager, languageManager.Language, GetMemberRefs(context)); + } + } + + public static bool CanAnalyze(IMemberRef member, ILanguage language) { + member = ResolveReference(member); + return member is TypeDef || + member is FieldDef || + member is MethodDef || + PropertyNode.CanShow(member, language) || + EventNode.CanShow(member, language); + } + + static void Analyze(IMainToolWindowManager mainToolWindowManager, Lazy analyzerManager, ILanguage language, IEnumerable mrs) { + foreach (var mr in mrs) + Analyze(mainToolWindowManager, analyzerManager, language, mr); + } + + public static void Analyze(IMainToolWindowManager mainToolWindowManager, Lazy analyzerManager, ILanguage language, IMemberRef member) { + var memberDef = ResolveReference(member); + + var type = memberDef as TypeDef; + if (type != null) { + mainToolWindowManager.Show(AnalyzerToolWindowContent.THE_GUID); + analyzerManager.Value.Add(new TypeNode(type)); + } + + var field = memberDef as FieldDef; + if (field != null) { + mainToolWindowManager.Show(AnalyzerToolWindowContent.THE_GUID); + analyzerManager.Value.Add(new FieldNode(field)); + } + + var method = memberDef as MethodDef; + if (method != null) { + mainToolWindowManager.Show(AnalyzerToolWindowContent.THE_GUID); + analyzerManager.Value.Add(new MethodNode(method)); + } + + var propertyAnalyzer = PropertyNode.TryCreateAnalyzer(member, language); + if (propertyAnalyzer != null) { + mainToolWindowManager.Show(AnalyzerToolWindowContent.THE_GUID); + analyzerManager.Value.Add(propertyAnalyzer); + } + + var eventAnalyzer = EventNode.TryCreateAnalyzer(member, language); + if (eventAnalyzer != null) { + mainToolWindowManager.Show(AnalyzerToolWindowContent.THE_GUID); + analyzerManager.Value.Add(eventAnalyzer); + } + } + + static IMemberDef ResolveReference(object reference) { + if (reference is ITypeDefOrRef) + return ((ITypeDefOrRef)reference).ResolveTypeDef(); + else if (reference is IMethod && ((IMethod)reference).MethodSig != null) + return ((IMethod)reference).ResolveMethodDef(); + else if (reference is IField) + return ((IField)reference).ResolveFieldDef(); + else if (reference is PropertyDef) + return (PropertyDef)reference; + else if (reference is EventDef) + return (EventDef)reference; + return null; + } + } + + [ExportAutoLoaded] + sealed class RemoveAnalyzeCommand : IAutoLoaded { + readonly Lazy analyzerManager; + + [ImportingConstructor] + RemoveAnalyzeCommand(IWpfCommandManager wpfCommandManager, Lazy analyzerManager) { + this.analyzerManager = analyzerManager; + var cmds = wpfCommandManager.GetCommands(CommandConstants.GUID_ANALYZER_TREEVIEW); + cmds.Add(ApplicationCommands.Delete, (s, e) => DeleteNodes(), (s, e) => e.CanExecute = CanDeleteNodes, ModifierKeys.None, Key.Delete); + } + + bool CanDeleteNodes { + get { return GetNodes() != null; } + } + + void DeleteNodes() { + DeleteNodes(GetNodes()); + } + + ITreeNodeData[] GetNodes() { + return GetNodes(analyzerManager.Value.TreeView.TopLevelSelection); + } + + internal static ITreeNodeData[] GetNodes(ITreeNodeData[] nodes) { + if (nodes == null) + return null; + if (nodes.Length == 0 || !nodes.All(a => a.TreeNode.Parent != null && a.TreeNode.Parent.Parent == null)) + return null; + return nodes; + } + + internal static void DeleteNodes(ITreeNodeData[] nodes) { + if (nodes != null) { + foreach (var node in nodes) { + AnalyzerTreeNodeData.CancelSelfAndChildren(node); + node.TreeNode.Parent.Children.Remove(node.TreeNode); + } + } + } + } + + [ExportMenuItem(Header = "res:RemoveCommand", Icon = "Delete", InputGestureText = "res:ShortCutKeyDelete", Group = MenuConstants.GROUP_CTX_ANALYZER_OTHER, Order = 10)] + sealed class RemoveAnalyzeCtxMenuCommand : MenuItemBase { + public override bool IsVisible(IMenuItemContext context) { + return GetNodes(context) != null; + } + + static ITreeNodeData[] GetNodes(IMenuItemContext context) { + if (context.CreatorObject.Guid != new Guid(MenuConstants.GUIDOBJ_ANALYZER_TREEVIEW_GUID)) + return null; + return RemoveAnalyzeCommand.GetNodes(context.Find()); + } + + public override void Execute(IMenuItemContext context) { + RemoveAnalyzeCommand.DeleteNodes(GetNodes(context)); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/EntityNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/EntityNode.cs new file mode 100644 index 000000000..7ec08d502 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/EntityNode.cs @@ -0,0 +1,53 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 dnlib.DotNet; +using dnSpy.Contracts.Files; +using dnSpy.Contracts.TreeView; + +namespace dnSpy.Analyzer.TreeNodes { + abstract class EntityNode : AnalyzerTreeNodeData, IMDTokenNode { + public abstract IMemberRef Member { get; } + public abstract IMDTokenProvider Reference { get; } + public SourceRef? SourceRef { get; set; } + + public override bool Activate() { + Context.AnalyzerManager.OnActivated(this); + return true; + } + + public override bool HandleAssemblyListChanged(IDnSpyFile[] removedAssemblies, IDnSpyFile[] addedAssemblies) { + foreach (IDnSpyFile asm in removedAssemblies) { + if (this.Member.Module == asm.ModuleDef) + return false; // remove this node + } + HandleAssemblyListChanged(this.TreeNode, removedAssemblies, addedAssemblies); + return true; + } + + public override bool HandleModelUpdated(IDnSpyFile[] files) { + if (this.Member.Module == null) + return false; // remove this node + if ((this.Member is IField || this.Member is IMethod || this.Member is PropertyDef || this.Member is EventDef) && + this.Member.DeclaringType == null) + return false; + HandleModelUpdated(this.TreeNode, files); + return true; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/EventAccessorNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/EventAccessorNode.cs new file mode 100644 index 000000000..f0793ba79 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/EventAccessorNode.cs @@ -0,0 +1,40 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 dnlib.DotNet; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class EventAccessorNode : MethodNode { + readonly string name; + + public EventAccessorNode(MethodDef analyzedMethod, string name) + : base(analyzedMethod) { + this.name = name; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + if (name != null) + output.Write(name, TextTokenKind.Keyword); + else + base.Write(output, language); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/EventFiredByNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/EventFiredByNode.cs new file mode 100644 index 000000000..22f342903 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/EventFiredByNode.cs @@ -0,0 +1,130 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Concurrent; +using System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnlib.DotNet.Emit; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class EventFiredByNode : SearchNode { + readonly EventDef analyzedEvent; + readonly FieldDef eventBackingField; + readonly MethodDef eventFiringMethod; + + ConcurrentDictionary foundMethods; + + public EventFiredByNode(EventDef analyzedEvent) { + if (analyzedEvent == null) + throw new ArgumentNullException("analyzedEvent"); + + this.analyzedEvent = analyzedEvent; + + this.eventBackingField = GetBackingField(analyzedEvent); + var eventType = analyzedEvent.EventType.ResolveTypeDef(); + if (eventType != null) + this.eventFiringMethod = eventType.Methods.First(md => md.Name == "Invoke"); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.RaisedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + foundMethods = new ConcurrentDictionary(); + + foreach (var child in FindReferencesInType(analyzedEvent.DeclaringType)) { + yield return child; + } + + foundMethods = null; + } + + IEnumerable FindReferencesInType(TypeDef type) { + // HACK: in lieu of proper flow analysis, I'm going to use a simple heuristic + // If the method accesses the event's backing field, and calls invoke on a delegate + // with the same signature, then it is (most likely) raise the given event. + + foreach (MethodDef method in type.Methods) { + bool readBackingField = false; + if (!method.HasBody) + continue; + Instruction foundInstr = null; + foreach (Instruction instr in method.Body.Instructions) { + Code code = instr.OpCode.Code; + if (code == Code.Ldfld || code == Code.Ldflda) { + IField fr = instr.Operand as IField; + if (fr.ResolveFieldDef() == eventBackingField) { + readBackingField = true; + } + } + if (readBackingField && (code == Code.Callvirt || code == Code.Call)) { + IMethod mr = instr.Operand as IMethod; + if (mr != null && eventFiringMethod != null && mr.Name == eventFiringMethod.Name && mr.ResolveMethodDef() == eventFiringMethod) { + foundInstr = instr; + break; + } + } + } + + if (foundInstr != null) { + MethodDef codeLocation = GetOriginalCodeLocation(method) as MethodDef; + if (codeLocation != null && !HasAlreadyBeenFound(codeLocation)) { + var node = new MethodNode(codeLocation) { Context = Context }; + if (codeLocation == method) + node.SourceRef = new SourceRef(method, foundInstr.Offset, foundInstr.Operand as IMDTokenProvider); + yield return node; + } + } + } + } + + bool HasAlreadyBeenFound(MethodDef method) { + return !foundMethods.TryAdd(method, 0); + } + + // HACK: we should probably examine add/remove methods to determine this + static FieldDef GetBackingField(EventDef ev) { + var fieldName = ev.Name; + var vbStyleFieldName = fieldName + "Event"; + var fieldType = ev.EventType; + if (fieldType == null) + return null; + + foreach (var fd in ev.DeclaringType.Fields) { + if (fd.Name == fieldName || fd.Name == vbStyleFieldName) + if (new SigComparer().Equals(fd.FieldType, fieldType)) + return fd; + } + + return null; + } + + + public static bool CanShow(EventDef ev) { + return GetBackingField(ev) != null; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/EventNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/EventNode.cs new file mode 100644 index 000000000..4901a786b --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/EventNode.cs @@ -0,0 +1,107 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.TreeView; +using dnSpy.Decompiler.Shared; +using dnSpy.Shared.Files.TreeView; +using dnSpy.Shared.Highlighting; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class EventNode : EntityNode { + readonly EventDef analyzedEvent; + readonly bool hidesParent; + + public EventNode(EventDef analyzedEvent, bool hidesParent = false) { + if (analyzedEvent == null) + throw new ArgumentNullException("analyzedEvent"); + this.analyzedEvent = analyzedEvent; + this.hidesParent = hidesParent; + } + + public override void Initialize() { + this.TreeNode.LazyLoading = true; + } + + public override IMemberRef Member { + get { return analyzedEvent; } + } + + public override IMDTokenProvider Reference { + get { return analyzedEvent; } + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return dnImgMgr.GetImageReference(analyzedEvent); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + if (hidesParent) { + output.Write("(", TextTokenKind.Operator); + output.Write(dnSpy_Analyzer_Resources.HidesParent, TextTokenKind.Text); + output.Write(")", TextTokenKind.Operator); + output.WriteSpace(); + } + language.WriteType(output, analyzedEvent.DeclaringType, true); + output.Write(".", TextTokenKind.Operator); + new NodePrinter().Write(output, language, analyzedEvent, Context.ShowToken); + } + + public override IEnumerable CreateChildren() { + if (analyzedEvent.AddMethod != null) + yield return new EventAccessorNode(analyzedEvent.AddMethod, dnSpy_Analyzer_Resources.EventAdderTreeNodeName); + + if (analyzedEvent.RemoveMethod != null) + yield return new EventAccessorNode(analyzedEvent.RemoveMethod, dnSpy_Analyzer_Resources.EventRemoverTreeNodeName); + + foreach (var accessor in analyzedEvent.OtherMethods) + yield return new EventAccessorNode(accessor, null); + + if (EventFiredByNode.CanShow(analyzedEvent)) + yield return new EventFiredByNode(analyzedEvent); + + if (EventOverridesNode.CanShow(analyzedEvent)) + yield return new EventOverridesNode(analyzedEvent); + + if (InterfaceEventImplementedByNode.CanShow(analyzedEvent)) + yield return new InterfaceEventImplementedByNode(analyzedEvent); + } + + public static IAnalyzerTreeNodeData TryCreateAnalyzer(IMemberRef member, ILanguage language) { + if (CanShow(member, language)) + return new EventNode(member as EventDef); + else + return null; + } + + public static bool CanShow(IMemberRef member, ILanguage language) { + var eventDef = member as EventDef; + if (eventDef == null) + return false; + + return !language.ShowMember(eventDef.AddMethod ?? eventDef.RemoveMethod) + || EventOverridesNode.CanShow(eventDef); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/EventOverridesNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/EventOverridesNode.cs new file mode 100644 index 000000000..298822900 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/EventOverridesNode.cs @@ -0,0 +1,68 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class EventOverridesNode : SearchNode { + readonly EventDef analyzedEvent; + + public EventOverridesNode(EventDef analyzedEvent) { + if (analyzedEvent == null) + throw new ArgumentNullException("analyzedEvent"); + + this.analyzedEvent = analyzedEvent; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.OverriddenByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedEvent, FindReferencesInType); + return analyzer.PerformAnalysis(ct); + } + + IEnumerable FindReferencesInType(TypeDef type) { + if (!TypesHierarchyHelpers.IsBaseType(analyzedEvent.DeclaringType, type, resolveTypeArguments: false)) + yield break; + + foreach (EventDef eventDef in type.Events) { + if (TypesHierarchyHelpers.IsBaseEvent(analyzedEvent, eventDef)) { + MethodDef anyAccessor = eventDef.AddMethod ?? eventDef.RemoveMethod; + if (anyAccessor == null) + continue; + bool hidesParent = !anyAccessor.IsVirtual ^ anyAccessor.IsNewSlot; + yield return new EventNode(eventDef, hidesParent) { Context = Context }; + } + } + } + + public static bool CanShow(EventDef property) { + var accessor = property.AddMethod ?? property.RemoveMethod; + return accessor != null && accessor.IsVirtual && !accessor.IsFinal && !accessor.DeclaringType.IsInterface; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/FieldAccessNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/FieldAccessNode.cs new file mode 100644 index 000000000..4cfc7b188 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/FieldAccessNode.cs @@ -0,0 +1,118 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections; +using System.Collections.Generic; +using System.Threading; +using dnlib.DotNet; +using dnlib.DotNet.Emit; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class FieldAccessNode : SearchNode { + readonly bool showWrites; // true: show writes; false: show read access + readonly FieldDef analyzedField; + Lazy foundMethods; + readonly object hashLock = new object(); + + public FieldAccessNode(FieldDef analyzedField, bool showWrites) { + if (analyzedField == null) + throw new ArgumentNullException("analyzedField"); + + this.analyzedField = analyzedField; + this.showWrites = showWrites; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(showWrites ? dnSpy_Analyzer_Resources.AssignedByTreeNode : dnSpy_Analyzer_Resources.ReadByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + foundMethods = new Lazy(LazyThreadSafetyMode.ExecutionAndPublication); + + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedField, FindReferencesInType); + foreach (var child in analyzer.PerformAnalysis(ct)) { + yield return child; + } + + foundMethods = null; + } + + IEnumerable FindReferencesInType(TypeDef type) { + foreach (MethodDef method in type.Methods) { + if (!method.HasBody) + continue; + Instruction foundInstr = null; + foreach (Instruction instr in method.Body.Instructions) { + if (CanBeReference(instr.OpCode.Code)) { + IField fr = instr.Operand as IField; + if (fr.ResolveFieldDef() == analyzedField && + Helpers.IsReferencedBy(analyzedField.DeclaringType, fr.DeclaringType)) { + foundInstr = instr; + break; + } + } + } + + if (foundInstr != null) { + MethodDef codeLocation = GetOriginalCodeLocation(method) as MethodDef; + if (codeLocation != null && !HasAlreadyBeenFound(codeLocation)) { + var node = new MethodNode(codeLocation) { Context = Context }; + if (codeLocation == method) + node.SourceRef = new SourceRef(method, foundInstr.Offset, foundInstr.Operand as IMDTokenProvider); + yield return node; + } + } + } + } + + bool CanBeReference(Code code) { + switch (code) { + case Code.Ldfld: + case Code.Ldsfld: + return !showWrites; + case Code.Stfld: + case Code.Stsfld: + return showWrites; + case Code.Ldflda: + case Code.Ldsflda: + case Code.Ldtoken: + return true; // always show address-loading + default: + return false; + } + } + + bool HasAlreadyBeenFound(MethodDef method) { + Hashtable hashtable = foundMethods.Value; + lock (hashLock) { + if (hashtable.Contains(method)) { + return true; + } + else { + hashtable.Add(method, null); + return false; + } + } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/FieldNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/FieldNode.cs new file mode 100644 index 000000000..b18634dc1 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/FieldNode.cs @@ -0,0 +1,67 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using dnlib.DotNet; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.TreeView; +using dnSpy.Decompiler.Shared; +using dnSpy.Shared.Files.TreeView; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class FieldNode : EntityNode { + readonly FieldDef analyzedField; + + public FieldNode(FieldDef analyzedField) { + if (analyzedField == null) + throw new ArgumentNullException("analyzedField"); + this.analyzedField = analyzedField; + } + + public override void Initialize() { + this.TreeNode.LazyLoading = true; + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return dnImgMgr.GetImageReference(analyzedField); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + language.WriteType(output, analyzedField.DeclaringType, true); + output.Write(".", TextTokenKind.Operator); + new NodePrinter().Write(output, language, analyzedField, Context.ShowToken); + } + + public override IEnumerable CreateChildren() { + yield return new FieldAccessNode(analyzedField, false); + if (!analyzedField.IsLiteral) + yield return new FieldAccessNode(analyzedField, true); + } + + public override IMemberRef Member { + get { return analyzedField; } + } + + public override IMDTokenProvider Reference { + get { return analyzedField; } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/Helpers.cs b/Plugins/dnSpy.Analyzer/TreeNodes/Helpers.cs new file mode 100644 index 000000000..5363a8215 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/Helpers.cs @@ -0,0 +1,146 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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.Linq; +using dnlib.DotNet; +using dnlib.DotNet.Emit; + +namespace dnSpy.Analyzer.TreeNodes { + static class Helpers { + public static bool IsReferencedBy(TypeDef type, ITypeDefOrRef typeRef) { + return IsReferencedBy(type, typeRef, 0); + } + + static bool IsReferencedBy(TypeDef type, ITypeDefOrRef typeRef, int depth) { + if (depth >= 30) + return false; + // TODO: move it to a better place after adding support for more cases. + if (type == null) + return false; + if (typeRef == null) + return false; + + if (type == typeRef) + return true; + if (type.Name != typeRef.Name) + return false; + if (type.Namespace != typeRef.Namespace) + return false; + + if (type.DeclaringType != null || typeRef.DeclaringType != null) { + if (type.DeclaringType == null || typeRef.DeclaringType == null) + return false; + if (!IsReferencedBy(type.DeclaringType, typeRef.DeclaringType, depth + 1)) + return false; + } + + return true; + } + + public static IMemberRef GetOriginalCodeLocation(IMemberRef member) { + if (member is MethodDef) + return GetOriginalCodeLocation((MethodDef)member); + return member; + } + + static MethodDef GetOriginalCodeLocation(MethodDef method) { + if (IsCompilerGenerated(method)) { + return FindMethodUsageInType(method.DeclaringType, method) ?? method; + } + + var typeUsage = GetOriginalCodeLocation(method.DeclaringType); + + return typeUsage ?? method; + } + + /// + /// Given a compiler-generated type, returns the method where that type is used. + /// Used to detect the 'parent method' for a lambda/iterator/async state machine. + /// + static MethodDef GetOriginalCodeLocation(TypeDef type) { + if (type != null && type.DeclaringType != null && IsCompilerGenerated(type)) { + if (type.IsValueType) { + // Value types might not have any constructor; but they must be stored in a local var + // because 'initobj' (or 'call .ctor') expects a managed ref. + return FindVariableOfTypeUsageInType(type.DeclaringType, type); + } + else { + MethodDef constructor = GetTypeConstructor(type); + if (constructor == null) + return null; + return FindMethodUsageInType(type.DeclaringType, constructor); + } + } + return null; + } + + static MethodDef GetTypeConstructor(TypeDef type) { + return type.FindConstructors().FirstOrDefault(); + } + + static MethodDef FindMethodUsageInType(TypeDef type, MethodDef analyzedMethod) { + string name = analyzedMethod.Name; + foreach (MethodDef method in type.Methods) { + bool found = false; + if (!method.HasBody) + continue; + foreach (Instruction instr in method.Body.Instructions) { + IMethod mr = instr.Operand as IMethod; + if (mr != null && !mr.IsField && mr.Name == name && + IsReferencedBy(analyzedMethod.DeclaringType, mr.DeclaringType) && + mr.ResolveMethodDef() == analyzedMethod) { + found = true; + break; + } + } + + if (found) + return method; + } + return null; + } + + static MethodDef FindVariableOfTypeUsageInType(TypeDef type, TypeDef variableType) { + foreach (MethodDef method in type.Methods) { + bool found = false; + if (!method.HasBody) + continue; + foreach (var v in method.Body.Variables) { + if (ResolveWithinSameModule(v.Type.ToTypeDefOrRef()) == variableType) { + found = true; + break; + } + } + + if (found) + return method; + } + return null; + } + + static TypeDef ResolveWithinSameModule(ITypeDefOrRef type) { + if (type != null && type.Scope == type.Module) + return type.ResolveTypeDef(); + return null; + } + + static bool IsCompilerGenerated(this IHasCustomAttribute hca) { + return hca != null && hca.CustomAttributes.IsDefined("System.Runtime.CompilerServices.CompilerGeneratedAttribute"); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/IAnalyzerTreeNodeData.cs b/Plugins/dnSpy.Analyzer/TreeNodes/IAnalyzerTreeNodeData.cs new file mode 100644 index 000000000..910eac1ea --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/IAnalyzerTreeNodeData.cs @@ -0,0 +1,53 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using dnSpy.Contracts.Files; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.TreeView; + +namespace dnSpy.Analyzer.TreeNodes { + interface IAnalyzerTreeNodeData : ITreeNodeData { + /// + /// Gets the context. Initialized by the owner. + /// + IAnalyzerTreeNodeDataContext Context { get; set; } + + /// + /// ToString() + /// + /// Language + /// + string ToString(ILanguage language); + + /// + /// Called when files have been added/removed from the files list + /// + /// Removed files + /// Added files + /// + bool HandleAssemblyListChanged(IDnSpyFile[] removedAssemblies, IDnSpyFile[] addedAssemblies); + + /// + /// Called when a file has been modified + /// + /// Files + /// + bool HandleModelUpdated(IDnSpyFile[] files); + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/IAnalyzerTreeNodeDataContext.cs b/Plugins/dnSpy.Analyzer/TreeNodes/IAnalyzerTreeNodeDataContext.cs new file mode 100644 index 000000000..6c24b5699 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/IAnalyzerTreeNodeDataContext.cs @@ -0,0 +1,35 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using dnSpy.Contracts.Files; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; + +namespace dnSpy.Analyzer.TreeNodes { + interface IAnalyzerTreeNodeDataContext { + bool UseNewRenderer { get; } + bool SingleClickExpandsChildren { get; } + bool SyntaxHighlight { get; } + bool ShowToken { get; } + ILanguage Language { get; } + IDotNetImageManager DotNetImageManager { get; } + IFileManager FileManager { get; } + IAnalyzerManager AnalyzerManager { get; } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/IAsyncCancellable.cs b/Plugins/dnSpy.Analyzer/TreeNodes/IAsyncCancellable.cs new file mode 100644 index 000000000..f10b3fb0d --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/IAsyncCancellable.cs @@ -0,0 +1,24 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +namespace dnSpy.Analyzer.TreeNodes { + interface IAsyncCancellable { + void Cancel(); + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/InterfaceEventImplementedByNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/InterfaceEventImplementedByNode.cs new file mode 100644 index 000000000..26a4c889b --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/InterfaceEventImplementedByNode.cs @@ -0,0 +1,84 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class InterfaceEventImplementedByNode : SearchNode { + readonly EventDef analyzedEvent; + readonly MethodDef analyzedMethod; + + public InterfaceEventImplementedByNode(EventDef analyzedEvent) { + if (analyzedEvent == null) + throw new ArgumentNullException("analyzedEvent"); + + this.analyzedEvent = analyzedEvent; + this.analyzedMethod = this.analyzedEvent.AddMethod ?? this.analyzedEvent.RemoveMethod; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.ImplementedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + if (analyzedMethod == null) + yield break; + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedMethod, FindReferencesInType); + foreach (var child in analyzer.PerformAnalysis(ct)) { + yield return child; + } + } + + IEnumerable FindReferencesInType(TypeDef type) { + if (!type.HasInterfaces || analyzedMethod == null) + yield break; + var iff = type.Interfaces.FirstOrDefault(i => new SigComparer().Equals(i.Interface, analyzedMethod.DeclaringType)); + ITypeDefOrRef implementedInterfaceRef = iff == null ? null : iff.Interface; + if (implementedInterfaceRef == null) + yield break; + + //TODO: Can we compare event types too? + foreach (EventDef ev in type.Events.Where(e => e.Name == analyzedEvent.Name)) { + MethodDef accessor = ev.AddMethod ?? ev.RemoveMethod; + if (accessor != null && TypesHierarchyHelpers.MatchInterfaceMethod(accessor, analyzedMethod, implementedInterfaceRef)) { + yield return new EventNode(ev) { Context = Context }; + } + } + + foreach (EventDef ev in type.Events.Where(e => e.Name.EndsWith(analyzedEvent.Name))) { + MethodDef accessor = ev.AddMethod ?? ev.RemoveMethod; + if (accessor != null && accessor.HasOverrides && + accessor.Overrides.Any(m => m.MethodDeclaration.ResolveMethodDef() == analyzedMethod)) { + yield return new EventNode(ev) { Context = Context }; + } + } + } + + public static bool CanShow(EventDef ev) { + return ev.DeclaringType.IsInterface; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/InterfaceMethodImplementedByNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/InterfaceMethodImplementedByNode.cs new file mode 100644 index 000000000..13f1ffd71 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/InterfaceMethodImplementedByNode.cs @@ -0,0 +1,75 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class InterfaceMethodImplementedByNode : SearchNode { + readonly MethodDef analyzedMethod; + + public InterfaceMethodImplementedByNode(MethodDef analyzedMethod) { + if (analyzedMethod == null) + throw new ArgumentNullException("analyzedMethod"); + + this.analyzedMethod = analyzedMethod; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.ImplementedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedMethod, FindReferencesInType); + return analyzer.PerformAnalysis(ct); + } + + IEnumerable FindReferencesInType(TypeDef type) { + if (!type.HasInterfaces) + yield break; + var iff = type.Interfaces.FirstOrDefault(i => new SigComparer().Equals(i.Interface, analyzedMethod.DeclaringType)); + ITypeDefOrRef implementedInterfaceRef = iff == null ? null : iff.Interface; + if (implementedInterfaceRef == null) + yield break; + + //TODO: Can we compare method sigs too? + foreach (MethodDef method in type.Methods.Where(m => m.Name == analyzedMethod.Name)) { + if (TypesHierarchyHelpers.MatchInterfaceMethod(method, analyzedMethod, implementedInterfaceRef)) { + yield return new MethodNode(method) { Context = Context }; + } + } + + foreach (MethodDef method in type.Methods) { + if (method.HasOverrides && method.Overrides.Any(m => m.MethodDeclaration.ResolveMethodDef() == analyzedMethod)) { + yield return new MethodNode(method) { Context = Context }; + } + } + } + + public static bool CanShow(MethodDef method) { + return method.DeclaringType.IsInterface; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/InterfacePropertyImplementedByNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/InterfacePropertyImplementedByNode.cs new file mode 100644 index 000000000..6e0dbde17 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/InterfacePropertyImplementedByNode.cs @@ -0,0 +1,83 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class InterfacePropertyImplementedByNode : SearchNode { + readonly PropertyDef analyzedProperty; + readonly MethodDef analyzedMethod; + + public InterfacePropertyImplementedByNode(PropertyDef analyzedProperty) { + if (analyzedProperty == null) + throw new ArgumentNullException("analyzedProperty"); + + this.analyzedProperty = analyzedProperty; + this.analyzedMethod = this.analyzedProperty.GetMethod ?? this.analyzedProperty.SetMethod; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.ImplementedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + if (analyzedMethod == null) + return new List(); + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedMethod, FindReferencesInType); + return analyzer.PerformAnalysis(ct); + } + + IEnumerable FindReferencesInType(TypeDef type) { + if (analyzedMethod == null) + yield break; + if (!type.HasInterfaces) + yield break; + var iff = type.Interfaces.FirstOrDefault(i => new SigComparer().Equals(i.Interface, analyzedMethod.DeclaringType)); + ITypeDefOrRef implementedInterfaceRef = iff == null ? null : iff.Interface; + if (implementedInterfaceRef == null) + yield break; + + //TODO: Can we compare property sigs too? + foreach (PropertyDef property in type.Properties.Where(e => e.Name == analyzedProperty.Name)) { + MethodDef accessor = property.GetMethod ?? property.SetMethod; + if (accessor != null && TypesHierarchyHelpers.MatchInterfaceMethod(accessor, analyzedMethod, implementedInterfaceRef)) { + yield return new PropertyNode(property) { Context = Context }; + } + } + + foreach (PropertyDef property in type.Properties.Where(e => e.Name.EndsWith(analyzedProperty.Name))) { + MethodDef accessor = property.GetMethod ?? property.SetMethod; + if (accessor != null && accessor.HasOverrides && accessor.Overrides.Any(m => m.MethodDeclaration.ResolveMethodDef() == analyzedMethod)) { + yield return new PropertyNode(property) { Context = Context }; + } + } + } + + public static bool CanShow(PropertyDef property) { + return property.DeclaringType.IsInterface; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/MethodNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/MethodNode.cs new file mode 100644 index 000000000..edcafc679 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/MethodNode.cs @@ -0,0 +1,87 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.TreeView; +using dnSpy.Decompiler.Shared; +using dnSpy.Shared.Files.TreeView; +using dnSpy.Shared.Highlighting; + +namespace dnSpy.Analyzer.TreeNodes { + class MethodNode : EntityNode { + readonly MethodDef analyzedMethod; + readonly bool hidesParent; + + public MethodNode(MethodDef analyzedMethod, bool hidesParent = false) { + if (analyzedMethod == null) + throw new ArgumentNullException("analyzedMethod"); + this.analyzedMethod = analyzedMethod; + this.hidesParent = hidesParent; + } + + public override void Initialize() { + this.TreeNode.LazyLoading = true; + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return dnImgMgr.GetImageReference(analyzedMethod); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + if (hidesParent) { + output.Write("(", TextTokenKind.Operator); + output.Write(dnSpy_Analyzer_Resources.HidesParent, TextTokenKind.Text); + output.Write(")", TextTokenKind.Operator); + output.WriteSpace(); + } + language.WriteType(output, analyzedMethod.DeclaringType, true); + output.Write(".", TextTokenKind.Operator); + new NodePrinter().Write(output, language, analyzedMethod, Context.ShowToken); + } + + public override IEnumerable CreateChildren() { + if (analyzedMethod.HasBody) + yield return new MethodUsesNode(analyzedMethod); + + if (analyzedMethod.IsVirtual && !(analyzedMethod.IsNewSlot && analyzedMethod.IsFinal)) + yield return new VirtualMethodUsedByNode(analyzedMethod); + else + yield return new MethodUsedByNode(analyzedMethod); + + if (MethodOverridesNode.CanShow(analyzedMethod)) + yield return new MethodOverridesNode(analyzedMethod); + + if (InterfaceMethodImplementedByNode.CanShow(analyzedMethod)) + yield return new InterfaceMethodImplementedByNode(analyzedMethod); + } + + public override IMemberRef Member { + get { return analyzedMethod; } + } + + public override IMDTokenProvider Reference { + get { return analyzedMethod; } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/MethodOverridesNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/MethodOverridesNode.cs new file mode 100644 index 000000000..d78212948 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/MethodOverridesNode.cs @@ -0,0 +1,79 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + /// + /// Searches for overrides of the analyzed method. + /// + sealed class MethodOverridesNode : SearchNode { + readonly MethodDef analyzedMethod; + + public MethodOverridesNode(MethodDef analyzedMethod) { + if (analyzedMethod == null) + throw new ArgumentNullException("analyzedMethod"); + + this.analyzedMethod = analyzedMethod; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.OverriddenByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedMethod, FindReferencesInType); + return analyzer.PerformAnalysis(ct); + } + + IEnumerable FindReferencesInType(TypeDef type) { + IAnalyzerTreeNodeData newNode = null; + try { + if (!TypesHierarchyHelpers.IsBaseType(analyzedMethod.DeclaringType, type, resolveTypeArguments: false)) + yield break; + + foreach (MethodDef method in type.Methods) { + if (TypesHierarchyHelpers.IsBaseMethod(analyzedMethod, method)) { + bool hidesParent = !method.IsVirtual ^ method.IsNewSlot; + newNode = new MethodNode(method, hidesParent) { Context = Context }; + } + } + } + catch (ResolveException) { + // ignore this type definition. maybe add a notification about such cases. + } + + if (newNode != null) + yield return newNode; + } + + public static bool CanShow(MethodDef method) { + return method.IsVirtual && + !method.IsFinal && + !method.DeclaringType.IsSealed && + !method.DeclaringType.IsInterface; // interface methods are definitions not implementations - cannot be overridden + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/MethodUsedByNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/MethodUsedByNode.cs new file mode 100644 index 000000000..a8e45a5a6 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/MethodUsedByNode.cs @@ -0,0 +1,89 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Concurrent; +using System.Collections.Generic; +using System.Threading; +using dnlib.DotNet; +using dnlib.DotNet.Emit; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class MethodUsedByNode : SearchNode { + readonly MethodDef analyzedMethod; + ConcurrentDictionary foundMethods; + + public MethodUsedByNode(MethodDef analyzedMethod) { + if (analyzedMethod == null) + throw new ArgumentNullException("analyzedMethod"); + + this.analyzedMethod = analyzedMethod; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.UsedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + foundMethods = new ConcurrentDictionary(); + + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedMethod, FindReferencesInType); + foreach (var child in analyzer.PerformAnalysis(ct)) { + yield return child; + } + + foundMethods = null; + } + + IEnumerable FindReferencesInType(TypeDef type) { + string name = analyzedMethod.Name; + foreach (MethodDef method in type.Methods) { + if (!method.HasBody) + continue; + Instruction foundInstr = null; + foreach (Instruction instr in method.Body.Instructions) { + IMethod mr = instr.Operand as IMethod; + if (mr != null && !mr.IsField && mr.Name == name && + Helpers.IsReferencedBy(analyzedMethod.DeclaringType, mr.DeclaringType) && + mr.ResolveMethodDef() == analyzedMethod) { + foundInstr = instr; + break; + } + } + + if (foundInstr != null) { + MethodDef codeLocation = GetOriginalCodeLocation(method) as MethodDef; + if (codeLocation != null && !HasAlreadyBeenFound(codeLocation)) { + var node = new MethodNode(codeLocation) { Context = Context }; + if (codeLocation == method) + node.SourceRef = new SourceRef(method, foundInstr.Offset, foundInstr.Operand as IMDTokenProvider); + yield return node; + } + } + } + } + + bool HasAlreadyBeenFound(MethodDef method) { + return !foundMethods.TryAdd(method, 0); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/MethodUsesNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/MethodUsesNode.cs new file mode 100644 index 000000000..37ec5d0f2 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/MethodUsesNode.cs @@ -0,0 +1,88 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnlib.DotNet.Emit; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + /// + /// Shows the methods that are used by this method. + /// + sealed class MethodUsesNode : SearchNode { + readonly MethodDef analyzedMethod; + + public MethodUsesNode(MethodDef analyzedMethod) { + if (analyzedMethod == null) + throw new ArgumentNullException("analyzedMethod"); + + this.analyzedMethod = analyzedMethod; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.UsesTreeNode, TextTokenKind.Text); + } + + struct DefRef where T : IDnlibDef { + public readonly T Def; + public readonly SourceRef SourceRef; + public DefRef(T def, SourceRef sourceRef) { + this.Def = def; + this.SourceRef = sourceRef; + } + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + foreach (var f in GetUsedFields().Distinct()) { + yield return new FieldNode(f.Def) { Context = Context, SourceRef = f.SourceRef }; + } + foreach (var m in GetUsedMethods().Distinct()) { + yield return new MethodNode(m.Def) { Context = Context, SourceRef = m.SourceRef }; + } + } + + IEnumerable> GetUsedMethods() { + foreach (Instruction instr in analyzedMethod.Body.Instructions) { + IMethod mr = instr.Operand as IMethod; + if (mr != null && !mr.IsField) { + MethodDef def = mr.ResolveMethodDef(); + if (def != null) + yield return new DefRef(def, new SourceRef(analyzedMethod, instr.Offset, instr.Operand as IMDTokenProvider)); + } + } + } + + IEnumerable> GetUsedFields() { + foreach (Instruction instr in analyzedMethod.Body.Instructions) { + IField fr = instr.Operand as IField; + if (fr != null && !fr.IsMethod) { + FieldDef def = fr.ResolveFieldDef(); + if (def != null) + yield return new DefRef(def, new SourceRef(analyzedMethod, instr.Offset, instr.Operand as IMDTokenProvider)); + } + } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/ModuleNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/ModuleNode.cs new file mode 100644 index 000000000..c0c776928 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/ModuleNode.cs @@ -0,0 +1,51 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using dnlib.DotNet; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; +using dnSpy.Shared.Highlighting; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class ModuleNode : EntityNode { + readonly ModuleDef module; + + public override IMemberRef Member { + get { return null; } + } + + public override IMDTokenProvider Reference { + get { return module; } + } + + public ModuleNode(ModuleDef module) { + this.module = module; + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return dnImgMgr.GetImageReference(module); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(NameUtils.CleanIdentifier(module.Name), TextTokenKind.Module); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/PropertyAccessorNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/PropertyAccessorNode.cs new file mode 100644 index 000000000..4a2d68f89 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/PropertyAccessorNode.cs @@ -0,0 +1,40 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 dnlib.DotNet; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class PropertyAccessorNode : MethodNode { + readonly string name; + + public PropertyAccessorNode(MethodDef analyzedMethod, string name) + : base(analyzedMethod) { + this.name = name; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + if (name != null) + output.Write(name, TextTokenKind.Keyword); + else + base.Write(output, language); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/PropertyNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/PropertyNode.cs new file mode 100644 index 000000000..52d704fbc --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/PropertyNode.cs @@ -0,0 +1,103 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.TreeView; +using dnSpy.Decompiler.Shared; +using dnSpy.Shared.Files.TreeView; +using dnSpy.Shared.Highlighting; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class PropertyNode : EntityNode { + readonly PropertyDef analyzedProperty; + readonly bool isIndexer; + readonly bool hidesParent; + + public PropertyNode(PropertyDef analyzedProperty, bool hidesParent = false) { + if (analyzedProperty == null) + throw new ArgumentNullException("analyzedProperty"); + this.isIndexer = analyzedProperty.IsIndexer(); + this.analyzedProperty = analyzedProperty; + this.hidesParent = hidesParent; + } + + public override void Initialize() { + this.TreeNode.LazyLoading = true; + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return dnImgMgr.GetImageReference(analyzedProperty); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + if (hidesParent) { + output.Write("(", TextTokenKind.Operator); + output.Write(dnSpy_Analyzer_Resources.HidesParent, TextTokenKind.Text); + output.Write(")", TextTokenKind.Operator); + output.WriteSpace(); + } + language.WriteType(output, analyzedProperty.DeclaringType, true); + output.Write(".", TextTokenKind.Operator); + new NodePrinter().Write(output, language, analyzedProperty, Context.ShowToken, null); + } + + public override IEnumerable CreateChildren() { + if (analyzedProperty.GetMethod != null) + yield return new PropertyAccessorNode(analyzedProperty.GetMethod, dnSpy_Analyzer_Resources.PropertyGetterTreeNode); + if (analyzedProperty.SetMethod != null) + yield return new PropertyAccessorNode(analyzedProperty.SetMethod, dnSpy_Analyzer_Resources.PropertySetterTreeNode); + foreach (var accessor in analyzedProperty.OtherMethods) + yield return new PropertyAccessorNode(accessor, null); + + if (PropertyOverridesNode.CanShow(analyzedProperty)) + yield return new PropertyOverridesNode(analyzedProperty); + if (InterfacePropertyImplementedByNode.CanShow(analyzedProperty)) + yield return new InterfacePropertyImplementedByNode(analyzedProperty); + } + + public static IAnalyzerTreeNodeData TryCreateAnalyzer(IMemberRef member, ILanguage language) { + if (CanShow(member, language)) + return new PropertyNode(member as PropertyDef); + else + return null; + } + + public static bool CanShow(IMemberRef member, ILanguage language) { + var property = member as PropertyDef; + if (property == null) + return false; + + return !language.ShowMember(property.GetMethod ?? property.SetMethod) + || PropertyOverridesNode.CanShow(property); + } + + public override IMemberRef Member { + get { return analyzedProperty; } + } + + public override IMDTokenProvider Reference { + get { return analyzedProperty; } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/PropertyOverridesNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/PropertyOverridesNode.cs new file mode 100644 index 000000000..7a68c533d --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/PropertyOverridesNode.cs @@ -0,0 +1,69 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class PropertyOverridesNode : SearchNode { + readonly PropertyDef analyzedProperty; + + public PropertyOverridesNode(PropertyDef analyzedProperty) { + if (analyzedProperty == null) + throw new ArgumentNullException("analyzedProperty"); + + this.analyzedProperty = analyzedProperty; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.OverriddenByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedProperty, FindReferencesInType); + return analyzer.PerformAnalysis(ct); + } + + IEnumerable FindReferencesInType(TypeDef type) { + if (!TypesHierarchyHelpers.IsBaseType(analyzedProperty.DeclaringType, type, resolveTypeArguments: false)) + yield break; + + foreach (PropertyDef property in type.Properties) { + + if (TypesHierarchyHelpers.IsBaseProperty(analyzedProperty, property)) { + MethodDef anyAccessor = property.GetMethod ?? property.SetMethod; + if (anyAccessor == null) + continue; + bool hidesParent = !anyAccessor.IsVirtual ^ anyAccessor.IsNewSlot; + yield return new PropertyNode(property, hidesParent) { Context = Context }; + } + } + } + + public static bool CanShow(PropertyDef property) { + var accessor = property.GetMethod ?? property.SetMethod; + return accessor != null && accessor.IsVirtual && !accessor.IsFinal && !accessor.DeclaringType.IsInterface; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/ScopedWhereUsedAnalyzer.cs b/Plugins/dnSpy.Analyzer/TreeNodes/ScopedWhereUsedAnalyzer.cs new file mode 100644 index 000000000..7f912ae44 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/ScopedWhereUsedAnalyzer.cs @@ -0,0 +1,311 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnlib.Threading; +using dnSpy.Contracts.Files; + +namespace dnSpy.Analyzer.TreeNodes { + /// + /// Determines the accessibility domain of a member for where-used analysis. + /// + sealed class ScopedWhereUsedAnalyzer { + readonly ModuleDef moduleScope; + readonly IFileManager fileManager; + TypeDef typeScope; + + readonly Accessibility memberAccessibility = Accessibility.Public; + Accessibility typeAccessibility = Accessibility.Public; + readonly Func> typeAnalysisFunction; + + public ScopedWhereUsedAnalyzer(IFileManager fileManager, TypeDef type, Func> typeAnalysisFunction) { + this.typeScope = type; + this.moduleScope = type.Module; + this.typeAnalysisFunction = typeAnalysisFunction; + this.fileManager = fileManager; + } + + public ScopedWhereUsedAnalyzer(IFileManager fileManager, MethodDef method, Func> typeAnalysisFunction) + : this(fileManager, method.DeclaringType, typeAnalysisFunction) { + this.memberAccessibility = GetMethodAccessibility(method); + } + + public ScopedWhereUsedAnalyzer(IFileManager fileManager, PropertyDef property, Func> typeAnalysisFunction) + : this(fileManager, property.DeclaringType, typeAnalysisFunction) { + Accessibility getterAccessibility = (property.GetMethod == null) ? Accessibility.Private : GetMethodAccessibility(property.GetMethod); + Accessibility setterAccessibility = (property.SetMethod == null) ? Accessibility.Private : GetMethodAccessibility(property.SetMethod); + this.memberAccessibility = (Accessibility)Math.Max((int)getterAccessibility, (int)setterAccessibility); + } + + public ScopedWhereUsedAnalyzer(IFileManager fileManager, EventDef eventDef, Func> typeAnalysisFunction) + : this(fileManager, eventDef.DeclaringType, typeAnalysisFunction) { + // we only have to check the accessibility of the the get method + // [CLS Rule 30: The accessibility of an event and of its accessors shall be identical.] + this.memberAccessibility = GetMethodAccessibility(eventDef.AddMethod); + } + + public ScopedWhereUsedAnalyzer(IFileManager fileManager, FieldDef field, Func> typeAnalysisFunction) + : this(fileManager, field.DeclaringType, typeAnalysisFunction) { + switch (field.Attributes & FieldAttributes.FieldAccessMask) { + case FieldAttributes.Private: + default: + memberAccessibility = Accessibility.Private; + break; + case FieldAttributes.FamANDAssem: + memberAccessibility = Accessibility.FamilyAndInternal; + break; + case FieldAttributes.Assembly: + memberAccessibility = Accessibility.Internal; + break; + case FieldAttributes.PrivateScope: + case FieldAttributes.Family: + memberAccessibility = Accessibility.Family; + break; + case FieldAttributes.FamORAssem: + memberAccessibility = Accessibility.FamilyOrInternal; + break; + case FieldAttributes.Public: + memberAccessibility = Accessibility.Public; + break; + } + } + + Accessibility GetMethodAccessibility(MethodDef method) { + if (method == null) + return 0; + Accessibility accessibility; + switch (method.Attributes & MethodAttributes.MemberAccessMask) { + case MethodAttributes.Private: + default: + accessibility = Accessibility.Private; + break; + case MethodAttributes.FamANDAssem: + accessibility = Accessibility.FamilyAndInternal; + break; + case MethodAttributes.PrivateScope: + case MethodAttributes.Family: + accessibility = Accessibility.Family; + break; + case MethodAttributes.Assembly: + accessibility = Accessibility.Internal; + break; + case MethodAttributes.FamORAssem: + accessibility = Accessibility.FamilyOrInternal; + break; + case MethodAttributes.Public: + accessibility = Accessibility.Public; + break; + } + return accessibility; + } + + public IEnumerable PerformAnalysis(CancellationToken ct) { + if (memberAccessibility == Accessibility.Private) { + return FindReferencesInTypeScope(ct); + } + + DetermineTypeAccessibility(); + + if (typeAccessibility == Accessibility.Private) { + return FindReferencesInEnclosingTypeScope(ct); + } + + if (memberAccessibility == Accessibility.Internal || + memberAccessibility == Accessibility.FamilyAndInternal || + typeAccessibility == Accessibility.Internal || + typeAccessibility == Accessibility.FamilyAndInternal) + return FindReferencesInAssemblyAndFriends(ct); + + return FindReferencesGlobal(ct); + } + + void DetermineTypeAccessibility() { + while (typeScope.IsNested) { + Accessibility accessibility = GetNestedTypeAccessibility(typeScope); + if ((int)typeAccessibility > (int)accessibility) { + typeAccessibility = accessibility; + if (typeAccessibility == Accessibility.Private) + return; + } + typeScope = typeScope.DeclaringType; + } + + if (typeScope.IsNotPublic && + ((int)typeAccessibility > (int)Accessibility.Internal)) { + typeAccessibility = Accessibility.Internal; + } + } + + static Accessibility GetNestedTypeAccessibility(TypeDef type) { + Accessibility result; + switch (type.Attributes & TypeAttributes.VisibilityMask) { + case TypeAttributes.NestedPublic: + result = Accessibility.Public; + break; + case TypeAttributes.NestedPrivate: + result = Accessibility.Private; + break; + case TypeAttributes.NestedFamily: + result = Accessibility.Family; + break; + case TypeAttributes.NestedAssembly: + result = Accessibility.Internal; + break; + case TypeAttributes.NestedFamANDAssem: + result = Accessibility.FamilyAndInternal; + break; + case TypeAttributes.NestedFamORAssem: + result = Accessibility.FamilyOrInternal; + break; + default: + throw new InvalidOperationException(); + } + return result; + } + + /// + /// The effective accessibility of a member + /// + enum Accessibility { + Private, + FamilyAndInternal, + Internal, + Family, + FamilyOrInternal, + Public + } + + IEnumerable FindReferencesInAssemblyAndFriends(CancellationToken ct) { + var modules = GetModuleAndAnyFriends(moduleScope, ct); + return modules.AsParallel().WithCancellation(ct).SelectMany(a => FindReferencesInModule(a, ct)); + } + + IEnumerable FindReferencesGlobal(CancellationToken ct) { + var modules = GetReferencingModules(moduleScope, ct); + return modules.AsParallel().WithCancellation(ct).SelectMany(a => FindReferencesInModule(a, ct)); + } + + IEnumerable FindReferencesInModule(ModuleDef mod, CancellationToken ct) { + foreach (TypeDef type in TreeTraversal.PreOrder(mod.Types, t => t.NestedTypes)) { + ct.ThrowIfCancellationRequested(); + foreach (var result in typeAnalysisFunction(type)) { + ct.ThrowIfCancellationRequested(); + yield return result; + } + } + } + + IEnumerable FindReferencesInTypeScope(CancellationToken ct) { + foreach (TypeDef type in TreeTraversal.PreOrder(typeScope, t => t.NestedTypes)) { + ct.ThrowIfCancellationRequested(); + foreach (var result in typeAnalysisFunction(type)) { + ct.ThrowIfCancellationRequested(); + yield return result; + } + } + } + + IEnumerable FindReferencesInEnclosingTypeScope(CancellationToken ct) { + foreach (TypeDef type in TreeTraversal.PreOrder(typeScope.DeclaringType, t => t.NestedTypes)) { + ct.ThrowIfCancellationRequested(); + foreach (var result in typeAnalysisFunction(type)) { + ct.ThrowIfCancellationRequested(); + yield return result; + } + } + } + + IEnumerable GetReferencingModules(ModuleDef mod, CancellationToken ct) { + var asm = mod.Assembly; + if (asm == null) { + yield return mod; + yield break; + } + foreach (var m in mod.Assembly.Modules.GetSafeEnumerable()) + yield return m; + + var assemblies = fileManager.GetFiles().Where(a => a.AssemblyDef != null); + + foreach (var assembly in assemblies) { + ct.ThrowIfCancellationRequested(); + bool found = false; + foreach (var reference in assembly.AssemblyDef.Modules.GetSafeEnumerable().SelectMany(module => module.GetAssemblyRefs())) { + if (AssemblyNameComparer.CompareAll.CompareTo(asm, reference) == 0) { + found = true; + break; + } + } + if (found && AssemblyReferencesScopeType(assembly.AssemblyDef)) { + foreach (var m in assembly.AssemblyDef.Modules.GetSafeEnumerable()) + yield return m; + } + } + } + + IEnumerable GetModuleAndAnyFriends(ModuleDef mod, CancellationToken ct) { + var asm = mod.Assembly; + if (asm == null) { + yield return mod; + yield break; + } + foreach (var m in mod.Assembly.Modules.GetSafeEnumerable()) + yield return m; + + if (asm.HasCustomAttributes) { + var attributes = asm.CustomAttributes + .Where(attr => attr.TypeFullName == "System.Runtime.CompilerServices.InternalsVisibleToAttribute"); + var friendAssemblies = new HashSet(); + foreach (var attribute in attributes) { + if (attribute.ConstructorArguments.Count == 0) + continue; + string assemblyName = attribute.ConstructorArguments[0].Value as UTF8String; + if (assemblyName == null) + continue; + assemblyName = assemblyName.Split(',')[0]; // strip off any public key info + friendAssemblies.Add(assemblyName); + } + + if (friendAssemblies.Count > 0) { + var assemblies = fileManager.GetFiles().Where(a => a.AssemblyDef != null); + + foreach (var assembly in assemblies) { + ct.ThrowIfCancellationRequested(); + if (friendAssemblies.Contains(assembly.AssemblyDef.Name) && AssemblyReferencesScopeType(assembly.AssemblyDef)) { + foreach (var m in assembly.AssemblyDef.Modules.GetSafeEnumerable()) + yield return m; + } + } + } + } + } + + bool AssemblyReferencesScopeType(AssemblyDef asm) { + foreach (var mod in asm.Modules.GetSafeEnumerable()) { + foreach (var typeref in mod.GetTypeRefs()) { + if (new SigComparer().Equals(typeScope, typeref)) + return true; + } + } + return false; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/SearchNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/SearchNode.cs new file mode 100644 index 000000000..0b4f893d4 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/SearchNode.cs @@ -0,0 +1,99 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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.Collections.Generic; +using System.Diagnostics; +using System.Threading; +using dnSpy.Contracts.Files; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.TreeView; + +namespace dnSpy.Analyzer.TreeNodes { + /// + /// Base class for analyzer nodes that perform a search. + /// + abstract class SearchNode : AnalyzerTreeNodeData, IAsyncCancellable { + protected SearchNode() { + } + + public override void Initialize() { + TreeNode.LazyLoading = true; + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return new ImageReference(GetType().Assembly, "Search"); + } + + public override IEnumerable CreateChildren() { + Debug.Assert(asyncFetchChildrenHelper == null); + asyncFetchChildrenHelper = new AsyncFetchChildrenHelper(this, () => asyncFetchChildrenHelper = null); + yield break; + } + AsyncFetchChildrenHelper asyncFetchChildrenHelper; + + protected abstract IEnumerable FetchChildren(CancellationToken ct); + + internal IEnumerable FetchChildrenInternal(CancellationToken token) { + return FetchChildren(token); + } + + public override void OnIsVisibleChanged() { + if (!TreeNode.IsVisible && asyncFetchChildrenHelper != null && !asyncFetchChildrenHelper.CompletedSuccessfully) { + CancelAndClearChildren(); + TreeNode.LazyLoading = true; + } + } + + public override void OnIsExpandedChanged(bool isExpanded) { + if (!isExpanded && asyncFetchChildrenHelper != null && !asyncFetchChildrenHelper.CompletedSuccessfully) { + CancelAndClearChildren(); + TreeNode.LazyLoading = true; + } + } + + public override bool HandleAssemblyListChanged(IDnSpyFile[] removedAssemblies, IDnSpyFile[] addedAssemblies) { + // only cancel a running analysis if user has manually added/removed assemblies + bool manualAdd = false; + foreach (var asm in addedAssemblies) { + if (!asm.IsAutoLoaded) + manualAdd = true; + } + if (removedAssemblies.Length > 0 || manualAdd) { + CancelAndClearChildren(); + } + return true; + } + + public override bool HandleModelUpdated(IDnSpyFile[] files) { + CancelAndClearChildren(); + return true; + } + + void CancelAndClearChildren() { + AnalyzerTreeNodeData.CancelSelfAndChildren(this); + this.TreeNode.Children.Clear(); + this.TreeNode.LazyLoading = true; + } + + public void Cancel() { + if (asyncFetchChildrenHelper != null) + asyncFetchChildrenHelper.Cancel(); + asyncFetchChildrenHelper = null; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/SourceRef.cs b/Plugins/dnSpy.Analyzer/TreeNodes/SourceRef.cs new file mode 100644 index 000000000..5392dc125 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/SourceRef.cs @@ -0,0 +1,33 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using dnlib.DotNet; + +namespace dnSpy.Analyzer.TreeNodes { + struct SourceRef { + public readonly MethodDef Method; + public readonly uint ILOffset; + public readonly IMDTokenProvider Reference; + public SourceRef(MethodDef method, uint offset, IMDTokenProvider reference) { + this.Method = method; + this.ILOffset = offset; + this.Reference = reference; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/TypeExposedByNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/TypeExposedByNode.cs new file mode 100644 index 000000000..1c1a4bf7f --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/TypeExposedByNode.cs @@ -0,0 +1,147 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class TypeExposedByNode : SearchNode { + readonly TypeDef analyzedType; + + public TypeExposedByNode(TypeDef analyzedType) { + if (analyzedType == null) + throw new ArgumentNullException("analyzedType"); + + this.analyzedType = analyzedType; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.ExposedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedType, FindReferencesInType); + return analyzer.PerformAnalysis(ct); + } + + IEnumerable FindReferencesInType(TypeDef type) { + if (analyzedType.IsEnum && type == analyzedType) + yield break; + + if (!this.Context.Language.ShowMember(type)) + yield break; + + foreach (FieldDef field in type.Fields) { + if (TypeIsExposedBy(field)) { + yield return new FieldNode(field) { Context = Context }; + } + } + + foreach (PropertyDef property in type.Properties) { + if (TypeIsExposedBy(property)) { + yield return new PropertyNode(property) { Context = Context }; + } + } + + foreach (EventDef eventDef in type.Events) { + if (TypeIsExposedBy(eventDef)) { + yield return new EventNode(eventDef) { Context = Context }; + } + } + + foreach (MethodDef method in type.Methods) { + if (TypeIsExposedBy(method)) { + yield return new MethodNode(method) { Context = Context }; + } + } + } + + bool TypeIsExposedBy(FieldDef field) { + if (field.IsPrivate) + return false; + + return new SigComparer().Equals(analyzedType, field.FieldType); + } + + bool TypeIsExposedBy(PropertyDef property) { + if (IsPrivate(property)) + return false; + + return new SigComparer().Equals(analyzedType, property.PropertySig.GetRetType()); + } + + bool TypeIsExposedBy(EventDef eventDef) { + if (IsPrivate(eventDef)) + return false; + + return new SigComparer().Equals(eventDef.EventType, analyzedType); + } + + bool TypeIsExposedBy(MethodDef method) { + // if the method has overrides, it is probably an explicit interface member + // and should be considered part of the public API even though it is marked private. + if (method.IsPrivate) { + if (!method.HasOverrides) + return false; + var methDecl = method.Overrides[0].MethodDeclaration; + var typeDef = methDecl == null ? null : methDecl.DeclaringType.ResolveTypeDef(); + if (typeDef != null && !typeDef.IsInterface) + return false; + } + + // exclude methods with 'semantics'. for example, property getters & setters. + // HACK: this is a potentially fragile implementation, as the MethodSemantics may be extended to other uses at a later date. + if (method.SemanticsAttributes != MethodSemanticsAttributes.None) + return false; + + if (new SigComparer().Equals(analyzedType, method.ReturnType)) + return true; + + foreach (var parameter in method.Parameters) { + if (parameter.IsHiddenThisParameter) + continue; + if (new SigComparer().Equals(analyzedType, parameter.Type)) + return true; + } + + return false; + } + + static bool IsPrivate(PropertyDef property) { + bool isGetterPublic = (property.GetMethod != null && !property.GetMethod.IsPrivate); + bool isSetterPublic = (property.SetMethod != null && !property.SetMethod.IsPrivate); + return !(isGetterPublic || isSetterPublic); + } + + static bool IsPrivate(EventDef eventDef) { + bool isAdderPublic = (eventDef.AddMethod != null && !eventDef.AddMethod.IsPrivate); + bool isRemoverPublic = (eventDef.RemoveMethod != null && !eventDef.RemoveMethod.IsPrivate); + return !(isAdderPublic || isRemoverPublic); + } + + public static bool CanShow(TypeDef type) { + return true; + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/TypeExtensionMethodsNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/TypeExtensionMethodsNode.cs new file mode 100644 index 000000000..e38f20d82 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/TypeExtensionMethodsNode.cs @@ -0,0 +1,79 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class TypeExtensionMethodsNode : SearchNode { + readonly TypeDef analyzedType; + + public TypeExtensionMethodsNode(TypeDef analyzedType) { + if (analyzedType == null) + throw new ArgumentNullException("analyzedType"); + + this.analyzedType = analyzedType; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.ExtensionMethodsTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedType, FindReferencesInType); + return analyzer.PerformAnalysis(ct); + } + + IEnumerable FindReferencesInType(TypeDef type) { + if (!HasExtensionAttribute(type)) + yield break; + foreach (MethodDef method in type.Methods) { + if (method.IsStatic && HasExtensionAttribute(method)) { + int skip = GetParametersSkip(method.Parameters); + if (method.Parameters.Count > skip && new SigComparer().Equals(analyzedType, method.Parameters[skip].Type)) { + yield return new MethodNode(method) { Context = Context }; + } + } + } + } + + static int GetParametersSkip(IList parameters) { + if (parameters == null || parameters.Count == 0) + return 0; + if (parameters[0].IsHiddenThisParameter) + return 1; + return 0; + } + + bool HasExtensionAttribute(IHasCustomAttribute p) { + return p.CustomAttributes.Find("System.Runtime.CompilerServices.ExtensionAttribute") != null; + } + + + public static bool CanShow(TypeDef type) { + // show on all types except static classes + return !(type.IsAbstract && type.IsSealed); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/TypeInstantiationsNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/TypeInstantiationsNode.cs new file mode 100644 index 000000000..a56e786f6 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/TypeInstantiationsNode.cs @@ -0,0 +1,83 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Threading; +using dnlib.DotNet; +using dnlib.DotNet.Emit; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class TypeInstantiationsNode : SearchNode { + readonly TypeDef analyzedType; + readonly bool isSystemObject; + + public TypeInstantiationsNode(TypeDef analyzedType) { + if (analyzedType == null) + throw new ArgumentNullException("analyzedType"); + + this.analyzedType = analyzedType; + + this.isSystemObject = analyzedType.DefinitionAssembly.IsCorLib() && analyzedType.FullName == "System.Object"; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.InstantiatedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedType, FindReferencesInType); + return analyzer.PerformAnalysis(ct); + } + + IEnumerable FindReferencesInType(TypeDef type) { + foreach (MethodDef method in type.Methods) { + if (!method.HasBody) + continue; + + // ignore chained constructors + // (since object is the root of everything, we can short circuit the test in this case) + if (method.Name == ".ctor" && + (isSystemObject || analyzedType == type || TypesHierarchyHelpers.IsBaseType(analyzedType, type, false))) + continue; + + Instruction foundInstr = null; + foreach (Instruction instr in method.Body.Instructions) { + IMethod mr = instr.Operand as IMethod; + if (mr != null && !mr.IsField && mr.Name == ".ctor") { + if (Helpers.IsReferencedBy(analyzedType, mr.DeclaringType)) { + foundInstr = instr; + break; + } + } + } + + if (foundInstr != null) + yield return new MethodNode(method) { Context = Context, SourceRef = new SourceRef(method, foundInstr.Offset, foundInstr.Operand as IMDTokenProvider) }; + } + } + + public static bool CanShow(TypeDef type) { + return (type.IsClass && !(type.IsAbstract && type.IsSealed) && !type.IsEnum); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/TypeNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/TypeNode.cs new file mode 100644 index 000000000..c98e99c8e --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/TypeNode.cs @@ -0,0 +1,75 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using dnlib.DotNet; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Images; +using dnSpy.Contracts.Languages; +using dnSpy.Contracts.TreeView; +using dnSpy.Shared.Files.TreeView; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class TypeNode : EntityNode { + readonly TypeDef analyzedType; + + public TypeNode(TypeDef analyzedType) { + if (analyzedType == null) + throw new ArgumentNullException("analyzedType"); + this.analyzedType = analyzedType; + } + + public override void Initialize() { + this.TreeNode.LazyLoading = true; + } + + protected override ImageReference GetIcon(IDotNetImageManager dnImgMgr) { + return dnImgMgr.GetImageReference(analyzedType); + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + new NodePrinter().Write(output, language, analyzedType, Context.ShowToken); + } + + public override IEnumerable CreateChildren() { + if (AttributeAppliedToNode.CanShow(analyzedType)) + yield return new AttributeAppliedToNode(analyzedType); + + if (TypeInstantiationsNode.CanShow(analyzedType)) + yield return new TypeInstantiationsNode(analyzedType); + + if (TypeUsedByNode.CanShow(analyzedType)) + yield return new TypeUsedByNode(analyzedType); + + if (TypeExposedByNode.CanShow(analyzedType)) + yield return new TypeExposedByNode(analyzedType); + + if (TypeExtensionMethodsNode.CanShow(analyzedType)) + yield return new TypeExtensionMethodsNode(analyzedType); + } + + public override IMemberRef Member { + get { return analyzedType; } + } + + public override IMDTokenProvider Reference { + get { return analyzedType; } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/TypeUsedByNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/TypeUsedByNode.cs new file mode 100644 index 000000000..695df1a8c --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/TypeUsedByNode.cs @@ -0,0 +1,176 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class TypeUsedByNode : SearchNode { + readonly TypeDef analyzedType; + + public TypeUsedByNode(TypeDef analyzedType) { + if (analyzedType == null) + throw new ArgumentNullException("analyzedType"); + + this.analyzedType = analyzedType; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.UsedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedType, FindTypeUsage); + return analyzer.PerformAnalysis(ct) + .Cast() + .Where(n => n.Member.DeclaringType != analyzedType) + .Distinct(new AnalyzerEntityTreeNodeComparer()); + } + + IEnumerable FindTypeUsage(TypeDef type) { + if (type == null) + yield break; + if (type == analyzedType) + yield break; + + if (IsUsedInTypeDef(type)) + yield return new TypeNode(type) { Context = Context }; + + foreach (var field in type.Fields.Where(IsUsedInFieldRef)) + yield return new FieldNode(field) { Context = Context }; + + foreach (var method in type.Methods) { + SourceRef? sourceRef = null; + if (IsUsedInMethodDef(method, ref sourceRef)) + yield return HandleSpecialMethodNode(method, sourceRef); + } + } + + EntityNode HandleSpecialMethodNode(MethodDef method, SourceRef? sourceRef) { + var property = method.DeclaringType.Properties.FirstOrDefault(p => p.GetMethod == method || p.SetMethod == method); + if (property != null) + return new PropertyNode(property) { Context = Context, SourceRef = sourceRef }; + + return new MethodNode(method) { Context = Context, SourceRef = sourceRef }; + } + + bool IsUsedInTypeRefs(IEnumerable types) { + return types.Any(IsUsedInTypeRef); + } + + bool IsUsedInTypeRef(ITypeDefOrRef type) { + if (type == null) + return false; + + return TypeMatches(type.DeclaringType) + || TypeMatches(type); + } + + bool IsUsedInTypeDef(TypeDef type) { + if (type == null) + return false; + + return IsUsedInTypeRef(type) + || TypeMatches(type.BaseType) + || IsUsedInTypeRefs(type.Interfaces.Select(ii => ii.Interface)); + } + + bool IsUsedInFieldRef(IField field) { + if (field == null || !field.IsField) + return false; + + return TypeMatches(field.DeclaringType) + || TypeMatches(field.FieldSig.GetFieldType()); + } + + bool IsUsedInMethodRef(IMethod method) { + if (method == null || !method.IsMethod) + return false; + + return TypeMatches(method.DeclaringType) + || TypeMatches(method.MethodSig.GetRetType()) + || IsUsedInMethodParameters(method.GetParameters()); + } + + bool IsUsedInMethodDef(MethodDef method, ref SourceRef? sourceRef) { + return IsUsedInMethodRef(method) + || IsUsedInMethodBody(method, ref sourceRef); + } + + bool IsUsedInMethodBody(MethodDef method, ref SourceRef? sourceRef) { + if (method == null) + return false; + if (method.Body == null) + return false; + + foreach (var instruction in method.Body.Instructions) { + ITypeDefOrRef tr = instruction.Operand as ITypeDefOrRef; + if (IsUsedInTypeRef(tr)) { + sourceRef = new SourceRef(method, instruction.Offset, instruction.Operand as IMDTokenProvider); + return true; + } + IField fr = instruction.Operand as IField; + if (IsUsedInFieldRef(fr)) { + sourceRef = new SourceRef(method, instruction.Offset, instruction.Operand as IMDTokenProvider); + return true; + } + IMethod mr = instruction.Operand as IMethod; + if (IsUsedInMethodRef(mr)) { + sourceRef = new SourceRef(method, instruction.Offset, instruction.Operand as IMDTokenProvider); + return true; + } + } + + return false; + } + + bool IsUsedInMethodParameters(IEnumerable parameters) { + return parameters.Any(IsUsedInMethodParameter); + } + + bool IsUsedInMethodParameter(Parameter parameter) { + return !parameter.IsHiddenThisParameter && TypeMatches(parameter.Type); + } + + bool TypeMatches(IType tref) { + return tref != null && new SigComparer().Equals(analyzedType, tref); + } + + public static bool CanShow(TypeDef type) { + return type != null; + } + } + + sealed class AnalyzerEntityTreeNodeComparer : IEqualityComparer { + public bool Equals(EntityNode x, EntityNode y) { + return x.Member == y.Member; + } + + public int GetHashCode(EntityNode node) { + return node.Member.GetHashCode(); + } + } + +} diff --git a/Plugins/dnSpy.Analyzer/TreeNodes/VirtualMethodUsedByNode.cs b/Plugins/dnSpy.Analyzer/TreeNodes/VirtualMethodUsedByNode.cs new file mode 100644 index 000000000..6e77c1630 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeNodes/VirtualMethodUsedByNode.cs @@ -0,0 +1,132 @@ +// Copyright (c) 2011 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Concurrent; +using System.Collections.Generic; +using System.Linq; +using System.Threading; +using dnlib.DotNet; +using dnlib.DotNet.Emit; +using dnSpy.Analyzer.Properties; +using dnSpy.Contracts.Highlighting; +using dnSpy.Contracts.Languages; +using dnSpy.Decompiler.Shared; + +namespace dnSpy.Analyzer.TreeNodes { + sealed class VirtualMethodUsedByNode : SearchNode { + readonly MethodDef analyzedMethod; + ConcurrentDictionary foundMethods; + MethodDef baseMethod; + List possibleTypes; + + public VirtualMethodUsedByNode(MethodDef analyzedMethod) { + if (analyzedMethod == null) + throw new ArgumentNullException("analyzedMethod"); + + this.analyzedMethod = analyzedMethod; + } + + protected override void Write(ISyntaxHighlightOutput output, ILanguage language) { + output.Write(dnSpy_Analyzer_Resources.UsedByTreeNode, TextTokenKind.Text); + } + + protected override IEnumerable FetchChildren(CancellationToken ct) { + InitializeAnalyzer(); + + var analyzer = new ScopedWhereUsedAnalyzer(Context.FileManager, analyzedMethod, FindReferencesInType); + foreach (var child in analyzer.PerformAnalysis(ct)) { + yield return child; + } + + ReleaseAnalyzer(); + } + + void InitializeAnalyzer() { + foundMethods = new ConcurrentDictionary(); + + var baseMethods = TypesHierarchyHelpers.FindBaseMethods(analyzedMethod).ToArray(); + if (baseMethods.Length > 0) { + baseMethod = baseMethods[baseMethods.Length - 1]; + } + else + baseMethod = analyzedMethod; + + possibleTypes = new List(); + + ITypeDefOrRef type = analyzedMethod.DeclaringType.BaseType; + while (type != null) { + possibleTypes.Add(type); + var resolvedType = type.ResolveTypeDef(); + type = resolvedType == null ? null : resolvedType.BaseType; + } + } + + void ReleaseAnalyzer() { + foundMethods = null; + baseMethod = null; + } + + IEnumerable FindReferencesInType(TypeDef type) { + string name = analyzedMethod.Name; + foreach (MethodDef method in type.Methods) { + if (!method.HasBody) + continue; + Instruction foundInstr = null; + foreach (Instruction instr in method.Body.Instructions) { + IMethod mr = instr.Operand as IMethod; + if (mr != null && !mr.IsField && mr.Name == name) { + // explicit call to the requested method + if (instr.OpCode.Code == Code.Call + && Helpers.IsReferencedBy(analyzedMethod.DeclaringType, mr.DeclaringType) + && mr.ResolveMethodDef() == analyzedMethod) { + foundInstr = instr; + break; + } + // virtual call to base method + if (instr.OpCode.Code == Code.Callvirt) { + MethodDef md = mr.ResolveMethodDef(); + if (md == null) { + // cannot resolve the operand, so ignore this method + break; + } + if (md == baseMethod) { + foundInstr = instr; + break; + } + } + } + } + + if (foundInstr != null) { + MethodDef codeLocation = GetOriginalCodeLocation(method) as MethodDef; + if (codeLocation != null && !HasAlreadyBeenFound(codeLocation)) { + var node = new MethodNode(codeLocation) { Context = Context }; + if (codeLocation == method) + node.SourceRef = new SourceRef(method, foundInstr.Offset, foundInstr.Operand as IMDTokenProvider); + yield return node; + } + } + } + } + + bool HasAlreadyBeenFound(MethodDef method) { + return !foundMethods.TryAdd(method, 0); + } + } +} diff --git a/Plugins/dnSpy.Analyzer/TreeTraversal.cs b/Plugins/dnSpy.Analyzer/TreeTraversal.cs new file mode 100644 index 000000000..d7d99d86a --- /dev/null +++ b/Plugins/dnSpy.Analyzer/TreeTraversal.cs @@ -0,0 +1,109 @@ +// Copyright (c) 2010-2013 AlphaSierraPapa for the SharpDevelop Team +// +// 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 System.Collections.Generic; + +namespace dnSpy.Analyzer { + /// + /// Static helper methods for traversing trees. + /// + static class TreeTraversal { + /// + /// Converts a tree data structure into a flat list by traversing it in pre-order. + /// + /// The root element of the tree. + /// The function that gets the children of an element. + /// Iterator that enumerates the tree structure in pre-order. + public static IEnumerable PreOrder(T root, Func> recursion) { + return PreOrder(new T[] { root }, recursion); + } + + /// + /// Converts a tree data structure into a flat list by traversing it in pre-order. + /// + /// The root elements of the forest. + /// The function that gets the children of an element. + /// Iterator that enumerates the tree structure in pre-order. + public static IEnumerable PreOrder(IEnumerable input, Func> recursion) { + Stack> stack = new Stack>(); + try { + stack.Push(input.GetEnumerator()); + while (stack.Count > 0) { + while (stack.Peek().MoveNext()) { + T element = stack.Peek().Current; + yield return element; + IEnumerable children = recursion(element); + if (children != null) { + stack.Push(children.GetEnumerator()); + } + } + stack.Pop().Dispose(); + } + } + finally { + while (stack.Count > 0) { + stack.Pop().Dispose(); + } + } + } + + /// + /// Converts a tree data structure into a flat list by traversing it in post-order. + /// + /// The root element of the tree. + /// The function that gets the children of an element. + /// Iterator that enumerates the tree structure in post-order. + public static IEnumerable PostOrder(T root, Func> recursion) { + return PostOrder(new T[] { root }, recursion); + } + + /// + /// Converts a tree data structure into a flat list by traversing it in post-order. + /// + /// The root elements of the forest. + /// The function that gets the children of an element. + /// Iterator that enumerates the tree structure in post-order. + public static IEnumerable PostOrder(IEnumerable input, Func> recursion) { + Stack> stack = new Stack>(); + try { + stack.Push(input.GetEnumerator()); + while (stack.Count > 0) { + while (stack.Peek().MoveNext()) { + T element = stack.Peek().Current; + IEnumerable children = recursion(element); + if (children != null) { + stack.Push(children.GetEnumerator()); + } + else { + yield return element; + } + } + stack.Pop().Dispose(); + if (stack.Count > 0) + yield return stack.Peek().Current; + } + } + finally { + while (stack.Count > 0) { + stack.Pop().Dispose(); + } + } + } + } +} diff --git a/Plugins/dnSpy.Analyzer/dnSpy.Analyzer.csproj b/Plugins/dnSpy.Analyzer/dnSpy.Analyzer.csproj new file mode 100644 index 000000000..147390128 --- /dev/null +++ b/Plugins/dnSpy.Analyzer/dnSpy.Analyzer.csproj @@ -0,0 +1,138 @@ + + + + + Debug + AnyCPU + {82E9DEC4-564F-42D5-8856-AA17D3962829} + Library + Properties + dnSpy.Analyzer + dnSpy.Analyzer.Plugin + v4.6 + 512 + True + ..\..\dnSpy.snk + + + true + full + false + ..\..\dnSpy\dnSpy\bin\Debug\ + DEBUG;TRACE + prompt + 4 + 1685 + + + pdbonly + true + ..\..\dnSpy\dnSpy\bin\Release\ + TRACE + prompt + 4 + 1685 + + + + + + + + + + + + + + + + + + True + True + dnSpy.Analyzer.Resources.resx + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + {fdfc1237-143f-4919-8318-4926901f4639} + dnlib + + + {9b234472-0e22-428c-9345-c8d9ee5e06af} + dnSpy.Contracts + + + {a027546a-cf4b-47f9-bc53-ee1ad424ee41} + dnSpy.Decompiler.Shared + + + {7e7c2cf8-2057-4eaa-9dad-ab3022cf4037} + dnSpy.Shared + + + + + + + + + + Properties\AssemblyInfo.Shared.cs + + + PublicResXFileCodeGenerator + dnSpy.Analyzer.Resources.Designer.cs + + + + + + + \ No newline at end of file diff --git a/Plugins/dnSpy.AsmEditor/Assembly/AssemblyCommands.cs b/Plugins/dnSpy.AsmEditor/Assembly/AssemblyCommands.cs new file mode 100644 index 000000000..d8100f6e4 --- /dev/null +++ b/Plugins/dnSpy.AsmEditor/Assembly/AssemblyCommands.cs @@ -0,0 +1,490 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections.Generic; +using System.ComponentModel.Composition; +using System.Diagnostics; +using System.Linq; +using dnlib.DotNet; +using dnSpy.AsmEditor.Commands; +using dnSpy.AsmEditor.Properties; +using dnSpy.AsmEditor.SaveModule; +using dnSpy.AsmEditor.UndoRedo; +using dnSpy.Contracts.App; +using dnSpy.Contracts.Controls; +using dnSpy.Contracts.Files; +using dnSpy.Contracts.Files.Tabs; +using dnSpy.Contracts.Files.TreeView; +using dnSpy.Contracts.Menus; +using dnSpy.Contracts.Plugin; +using dnSpy.Contracts.TreeView; +using dnSpy.Shared.Files; +using dnSpy.Shared.Menus; +using dnSpy.Shared.MVVM; + +namespace dnSpy.AsmEditor.Assembly { + [ExportAutoLoaded] + sealed class CommandLoader : IAutoLoaded { + [ImportingConstructor] + CommandLoader(IWpfCommandManager wpfCommandManager, IFileTabManager fileTabManager, RemoveAssemblyCommand.EditMenuCommand removeCmd, AssemblySettingsCommand.EditMenuCommand settingsCmd) { + wpfCommandManager.AddRemoveCommand(removeCmd); + wpfCommandManager.AddSettingsCommand(fileTabManager, settingsCmd, null); + } + } + + [ExportMenuItem(Header = "res:DisableMMapIOCommand", Group = MenuConstants.GROUP_CTX_FILES_OTHER, Order = 50)] + sealed class DisableMemoryMappedIOCommand : MenuItemBase { + public override bool IsVisible(IMenuItemContext context) { + return context.CreatorObject.Guid == new Guid(MenuConstants.GUIDOBJ_FILES_TREEVIEW_GUID) && + (context.Find() ?? new ITreeNodeData[0]).Any(a => GetDnSpyFile(a) != null); + } + + static IDnSpyFile GetDnSpyFile(ITreeNodeData node) { + var fileNode = node as IDnSpyFileNode; + if (fileNode == null) + return null; + + var peImage = fileNode.DnSpyFile.PEImage; + if (peImage == null) { + var mod = fileNode.DnSpyFile.ModuleDef as ModuleDefMD; + peImage = mod == null ? null : mod.MetaData.PEImage; + } + + return peImage != null && peImage.IsMemoryMappedIO ? fileNode.DnSpyFile : null; + } + + public override void Execute(IMenuItemContext context) { + if (context.CreatorObject.Guid != new Guid(MenuConstants.GUIDOBJ_FILES_TREEVIEW_GUID)) + return; + var asms = new List(); + foreach (var node in (context.Find() ?? new ITreeNodeData[0])) { + var file = GetDnSpyFile(node); + if (file != null) + asms.Add(file); + } + foreach (var asm in asms) { + var peImage = asm.PEImage; + if (peImage != null) + peImage.UnsafeDisableMemoryMappedIO(); + } + } + } + + [DebuggerDisplay("{Description}")] + sealed class RemoveAssemblyCommand : IGCUndoCommand { + [ExportMenuItem(Header = "res:RemoveAssemblyCommand", Icon = "Delete", InputGestureText = "res:DeleteCommandKey", Group = MenuConstants.GROUP_CTX_FILES_ASMED_DELETE, Order = 0)] + sealed class FilesCommand : FilesContextMenuHandler { + readonly Lazy undoCommandManager; + readonly Lazy documentSaver; + readonly IAppWindow appWindow; + + [ImportingConstructor] + FilesCommand(Lazy undoCommandManager, Lazy documentSaver, IAppWindow appWindow) { + this.undoCommandManager = undoCommandManager; + this.documentSaver = documentSaver; + this.appWindow = appWindow; + } + + public override bool IsVisible(AsmEditorContext context) { + return RemoveAssemblyCommand.CanExecute(context.Nodes); + } + + public override void Execute(AsmEditorContext context) { + RemoveAssemblyCommand.Execute(undoCommandManager, documentSaver, appWindow, context.Nodes); + } + + public override string GetHeader(AsmEditorContext context) { + return RemoveAssemblyCommand.GetHeader(context.Nodes); + } + } + + [Export, ExportMenuItem(OwnerGuid = MenuConstants.APP_MENU_EDIT_GUID, Header = "res:RemoveAssemblyCommand", Icon = "Delete", InputGestureText = "res:DeleteCommandKey", Group = MenuConstants.GROUP_APP_MENU_EDIT_ASMED_DELETE, Order = 0)] + internal sealed class EditMenuCommand : EditMenuHandler { + readonly Lazy undoCommandManager; + readonly Lazy documentSaver; + readonly IAppWindow appWindow; + + [ImportingConstructor] + EditMenuCommand(Lazy undoCommandManager, Lazy documentSaver, IAppWindow appWindow) + : base(appWindow.FileTreeView) { + this.undoCommandManager = undoCommandManager; + this.documentSaver = documentSaver; + this.appWindow = appWindow; + } + + public override bool IsVisible(AsmEditorContext context) { + return RemoveAssemblyCommand.CanExecute(context.Nodes); + } + + public override void Execute(AsmEditorContext context) { + RemoveAssemblyCommand.Execute(undoCommandManager, documentSaver, appWindow, context.Nodes); + } + + public override string GetHeader(AsmEditorContext context) { + return RemoveAssemblyCommand.GetHeader(context.Nodes); + } + } + + static string GetHeader(ITreeNodeData[] nodes) { + if (nodes.Length == 1) + return string.Format(dnSpy_AsmEditor_Resources.RemoveCommand, UIUtils.EscapeMenuItemHeader(nodes[0].ToString())); + return string.Format(dnSpy_AsmEditor_Resources.RemoveAssembliesCommand, nodes.Length); + } + + static bool CanExecute(IFileTreeNodeData[] nodes) { + return nodes.Length > 0 && + nodes.All(n => n is IDnSpyFileNode && n.TreeNode.Parent == n.Context.FileTreeView.TreeView.Root); + } + + static void Execute(Lazy undoCommandManager, Lazy documentSaver, IAppWindow appWindow, IFileTreeNodeData[] nodes) { + if (!CanExecute(nodes)) + return; + + var asmNodes = nodes.Cast().ToArray(); + var files = asmNodes.SelectMany(a => a.DnSpyFile.GetAllChildrenAndSelf()); + if (!documentSaver.Value.AskUserToSaveIfModified(files)) + return; + + var keepNodes = new List(); + var freeNodes = new List(); + var onlyInRedoHistory = new List(); + foreach (var info in GetUndoRedoInfo(undoCommandManager.Value, asmNodes)) { + if (!info.IsInUndo && !info.IsInRedo) { + // This asm is safe to remove + freeNodes.Add(info.Node); + } + else if (!info.IsInUndo && info.IsInRedo) { + // If we add a RemoveAssemblyCommand, the redo history will be cleared, so this + // assembly will be cleared from the history and don't need to be kept. + onlyInRedoHistory.Add(info.Node); + } + else { + // The asm is in the undo history, and maybe in the redo history. We must keep it. + keepNodes.Add(info.Node); + } + } + + if (keepNodes.Count > 0 || onlyInRedoHistory.Count > 0) { + // We can't free the asm since older commands might reference it so we must record + // it in the history. The user can click Clear History to free everything. + foreach (var node in keepNodes) { + foreach (var f in node.DnSpyFile.GetAllChildrenAndSelf()) + MemoryMappedIOHelper.DisableMemoryMappedIO(f); + } + if (keepNodes.Count != 0) + undoCommandManager.Value.Add(new RemoveAssemblyCommand(appWindow.FileTreeView, keepNodes.ToArray())); + else + undoCommandManager.Value.ClearRedo(); + // Redo history was cleared + FreeAssemblies(onlyInRedoHistory); + } + + FreeAssemblies(freeNodes); + if (freeNodes.Count > 0 || onlyInRedoHistory.Count > 0) + undoCommandManager.Value.CallGc(); + } + + static void FreeAssemblies(IList nodes) { + if (nodes.Count == 0) + return; + nodes[0].Context.FileTreeView.Remove(nodes); + } + + struct UndoRedoInfo { + public bool IsInUndo; + public bool IsInRedo; + public IDnSpyFileNode Node; + + public UndoRedoInfo(IDnSpyFileNode node, bool isInUndo, bool isInRedo) { + this.IsInUndo = isInUndo; + this.IsInRedo = isInRedo; + this.Node = node; + } + } + + static IEnumerable GetUndoRedoInfo(IUndoCommandManager undoCommandManager, IEnumerable nodes) { + var modifiedUndoAsms = new HashSet(undoCommandManager.UndoObjects); + var modifiedRedoAsms = new HashSet(undoCommandManager.RedoObjects); + foreach (var node in nodes) { + var uo = undoCommandManager.GetUndoObject(node.DnSpyFile); + bool isInUndo = modifiedUndoAsms.Contains(uo); + bool isInRedo = modifiedRedoAsms.Contains(uo); + yield return new UndoRedoInfo(node, isInUndo, isInRedo); + } + } + + RootDnSpyFileNodeCreator[] savedStates; + + RemoveAssemblyCommand(IFileTreeView fileTreeView, IDnSpyFileNode[] asmNodes) { + this.savedStates = new RootDnSpyFileNodeCreator[asmNodes.Length]; + for (int i = 0; i < this.savedStates.Length; i++) + this.savedStates[i] = new RootDnSpyFileNodeCreator(fileTreeView, asmNodes[i]); + } + + public string Description { + get { return dnSpy_AsmEditor_Resources.RemoveAssemblyCommand; } + } + + public void Execute() { + for (int i = 0; i < savedStates.Length; i++) + savedStates[i].Remove(); + } + + public void Undo() { + for (int i = savedStates.Length - 1; i >= 0; i--) + savedStates[i].Add(); + } + + public IEnumerable ModifiedObjects { + get { + foreach (var savedState in savedStates) + yield return savedState.DnSpyFileNode; + } + } + + public bool CallGarbageCollectorAfterDispose { + get { return true; } + } + } + + [DebuggerDisplay("{Description}")] + sealed class AssemblySettingsCommand : IUndoCommand { + [ExportMenuItem(Header = "res:EditAssemblyCommand", Icon = "Settings", InputGestureText = "res:ShortcutKeyAltEnter", Group = MenuConstants.GROUP_CTX_FILES_ASMED_SETTINGS, Order = 0)] + sealed class FilesCommand : FilesContextMenuHandler { + readonly Lazy undoCommandManager; + readonly IAppWindow appWindow; + + [ImportingConstructor] + FilesCommand(Lazy undoCommandManager, IAppWindow appWindow) { + this.undoCommandManager = undoCommandManager; + this.appWindow = appWindow; + } + + public override bool IsVisible(AsmEditorContext context) { + return AssemblySettingsCommand.CanExecute(context.Nodes); + } + + public override void Execute(AsmEditorContext context) { + AssemblySettingsCommand.Execute(undoCommandManager, appWindow, context.Nodes); + } + } + + [Export, ExportMenuItem(OwnerGuid = MenuConstants.APP_MENU_EDIT_GUID, Header = "res:EditAssemblyCommand", Icon = "Settings", InputGestureText = "res:ShortcutKeyAltEnter", Group = MenuConstants.GROUP_APP_MENU_EDIT_ASMED_SETTINGS, Order = 0)] + internal sealed class EditMenuCommand : EditMenuHandler { + readonly Lazy undoCommandManager; + readonly IAppWindow appWindow; + + [ImportingConstructor] + EditMenuCommand(Lazy undoCommandManager, IAppWindow appWindow) + : base(appWindow.FileTreeView) { + this.undoCommandManager = undoCommandManager; + this.appWindow = appWindow; + } + + public override bool IsVisible(AsmEditorContext context) { + return AssemblySettingsCommand.CanExecute(context.Nodes); + } + + public override void Execute(AsmEditorContext context) { + AssemblySettingsCommand.Execute(undoCommandManager, appWindow, context.Nodes); + } + } + + static bool CanExecute(IFileTreeNodeData[] nodes) { + return nodes != null && + nodes.Length == 1 && + nodes[0] is IAssemblyFileNode; + } + + static void Execute(Lazy undoCommandManager, IAppWindow appWindow, IFileTreeNodeData[] nodes) { + if (!CanExecute(nodes)) + return; + + var asmNode = (IAssemblyFileNode)nodes[0]; + var module = asmNode.DnSpyFile.ModuleDef; + + var data = new AssemblyOptionsVM(new AssemblyOptions(asmNode.DnSpyFile.AssemblyDef), module, appWindow.LanguageManager); + var win = new AssemblyOptionsDlg(); + win.DataContext = data; + win.Owner = appWindow.MainWindow; + if (win.ShowDialog() != true) + return; + + undoCommandManager.Value.Add(new AssemblySettingsCommand(asmNode, data.CreateAssemblyOptions())); + } + + readonly IAssemblyFileNode asmNode; + readonly AssemblyOptions newOptions; + readonly AssemblyOptions origOptions; + readonly AssemblyRefInfo[] assemblyRefInfos; + + struct AssemblyRefInfo { + public readonly AssemblyRef AssemblyRef; + public readonly UTF8String OrigName; + public readonly PublicKeyBase OrigPublicKeyOrToken; + + public AssemblyRefInfo(AssemblyRef asmRef) { + this.AssemblyRef = asmRef; + this.OrigName = asmRef.Name; + this.OrigPublicKeyOrToken = asmRef.PublicKeyOrToken; + } + } + + AssemblySettingsCommand(IAssemblyFileNode asmNode, AssemblyOptions newOptions) { + this.asmNode = asmNode; + this.newOptions = newOptions; + this.origOptions = new AssemblyOptions(asmNode.DnSpyFile.AssemblyDef); + + if (newOptions.Name != origOptions.Name) + this.assemblyRefInfos = RefFinder.FindAssemblyRefsToThisModule(asmNode.DnSpyFile.ModuleDef).Where(a => AssemblyNameComparer.NameAndPublicKeyTokenOnly.Equals(a, asmNode.DnSpyFile.AssemblyDef)).Select(a => new AssemblyRefInfo(a)).ToArray(); + } + + public string Description { + get { return dnSpy_AsmEditor_Resources.EditAssemblyCommand2; } + } + + public void Execute() { + newOptions.CopyTo(asmNode.DnSpyFile.AssemblyDef); + if (assemblyRefInfos != null) { + var pkt = newOptions.PublicKey.Token; + foreach (var info in assemblyRefInfos) { + info.AssemblyRef.Name = newOptions.Name; + if (info.AssemblyRef.PublicKeyOrToken is PublicKeyToken) + info.AssemblyRef.PublicKeyOrToken = pkt; + else + info.AssemblyRef.PublicKeyOrToken = newOptions.PublicKey; + } + } + asmNode.TreeNode.RefreshUI(); + } + + public void Undo() { + origOptions.CopyTo(asmNode.DnSpyFile.AssemblyDef); + if (assemblyRefInfos != null) { + foreach (var info in assemblyRefInfos) { + info.AssemblyRef.Name = info.OrigName; + info.AssemblyRef.PublicKeyOrToken = info.OrigPublicKeyOrToken; + } + } + asmNode.TreeNode.RefreshUI(); + } + + public IEnumerable ModifiedObjects { + get { yield return asmNode; } + } + } + + [DebuggerDisplay("{Description}")] + sealed class CreateAssemblyCommand : IUndoCommand { + [ExportMenuItem(Header = "res:CreateAssemblyCommand", Icon = "NewAssembly", Group = MenuConstants.GROUP_CTX_FILES_ASMED_NEW, Order = 0)] + sealed class FilesCommand : FilesContextMenuHandler { + readonly Lazy undoCommandManager; + readonly IAppWindow appWindow; + + [ImportingConstructor] + FilesCommand(Lazy undoCommandManager, IAppWindow appWindow) { + this.undoCommandManager = undoCommandManager; + this.appWindow = appWindow; + } + + public override bool IsVisible(AsmEditorContext context) { + return CreateAssemblyCommand.CanExecute(context.Nodes); + } + + public override void Execute(AsmEditorContext context) { + CreateAssemblyCommand.Execute(undoCommandManager, appWindow, context.Nodes); + } + } + + [ExportMenuItem(OwnerGuid = MenuConstants.APP_MENU_EDIT_GUID, Header = "res:CreateAssemblyCommand", Icon = "NewAssembly", Group = MenuConstants.GROUP_APP_MENU_EDIT_ASMED_NEW, Order = 0)] + sealed class EditMenuCommand : EditMenuHandler { + readonly Lazy undoCommandManager; + readonly IAppWindow appWindow; + + [ImportingConstructor] + EditMenuCommand(Lazy undoCommandManager, IAppWindow appWindow) + : base(appWindow.FileTreeView) { + this.undoCommandManager = undoCommandManager; + this.appWindow = appWindow; + } + + public override bool IsVisible(AsmEditorContext context) { + return CreateAssemblyCommand.CanExecute(context.Nodes); + } + + public override void Execute(AsmEditorContext context) { + CreateAssemblyCommand.Execute(undoCommandManager, appWindow, context.Nodes); + } + } + + static bool CanExecute(IFileTreeNodeData[] nodes) { + return nodes != null && + (nodes.Length == 0 || nodes[0] is IDnSpyFileNode); + } + + static void Execute(Lazy undoCommandManager, IAppWindow appWindow, IFileTreeNodeData[] nodes) { + if (!CanExecute(nodes)) + return; + + var newModule = new ModuleDefUser(); + + var data = new AssemblyOptionsVM(AssemblyOptions.Create("MyAssembly"), newModule, appWindow.LanguageManager); + data.CanShowClrVersion = true; + var win = new AssemblyOptionsDlg(); + win.Title = dnSpy_AsmEditor_Resources.CreateAssemblyCommand2; + win.DataContext = data; + win.Owner = appWindow.MainWindow; + if (win.ShowDialog() != true) + return; + + var cmd = new CreateAssemblyCommand(undoCommandManager.Value, appWindow.FileTreeView, newModule, data.CreateAssemblyOptions()); + undoCommandManager.Value.Add(cmd); + appWindow.FileTabManager.FollowReference(cmd.fileNodeCreator.DnSpyFileNode); + } + + readonly RootDnSpyFileNodeCreator fileNodeCreator; + readonly IUndoCommandManager undoCommandManager; + + CreateAssemblyCommand(IUndoCommandManager undoCommandManager, IFileTreeView fileTreeView, ModuleDef newModule, AssemblyOptions options) { + this.undoCommandManager = undoCommandManager; + var module = Module.ModuleUtils.CreateModule(options.Name, Guid.NewGuid(), options.ClrVersion, ModuleKind.Dll, newModule); + options.CreateAssemblyDef(module).Modules.Add(module); + var file = DnSpyDotNetFile.CreateAssembly(DnSpyFileInfo.CreateFile(string.Empty), module, fileTreeView.FileManager.Settings.LoadPDBFiles); + this.fileNodeCreator = RootDnSpyFileNodeCreator.CreateAssembly(fileTreeView, file); + } + + public string Description { + get { return dnSpy_AsmEditor_Resources.CreateAssemblyCommand2; } + } + + public void Execute() { + fileNodeCreator.Add(); + undoCommandManager.MarkAsModified(undoCommandManager.GetUndoObject(fileNodeCreator.DnSpyFileNode.DnSpyFile)); + } + + public void Undo() { + fileNodeCreator.Remove(); + } + + public IEnumerable ModifiedObjects { + get { yield return fileNodeCreator.DnSpyFileNode; } + } + } +} diff --git a/Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptions.cs b/Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptions.cs new file mode 100644 index 000000000..aec617a94 --- /dev/null +++ b/Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptions.cs @@ -0,0 +1,81 @@ +/* + Copyright (C) 2014-2016 de4dot@gmail.com + + This file is part of dnSpy + + dnSpy is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + dnSpy is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with dnSpy. If not, see . +*/ + +using System; +using System.Collections.Generic; +using dnlib.DotNet; + +namespace dnSpy.AsmEditor.Assembly { + sealed class AssemblyOptions { + public AssemblyHashAlgorithm HashAlgorithm; + public Version Version; + public AssemblyAttributes Attributes; + public PublicKey PublicKey; + public UTF8String Name; + public string Culture; + public Module.ClrVersion ClrVersion; + public List CustomAttributes = new List(); + public List DeclSecurities = new List(); + + public AssemblyOptions() { + } + + public AssemblyOptions(AssemblyDef asm) { + this.HashAlgorithm = asm.HashAlgorithm; + this.Version = asm.Version; + this.Attributes = asm.Attributes; + this.PublicKey = asm.PublicKey; + this.Name = asm.Name; + this.Culture = asm.Culture; + this.ClrVersion = Module.ClrVersion.DefaultVersion; + this.CustomAttributes.AddRange(asm.CustomAttributes); + this.DeclSecurities.AddRange(asm.DeclSecurities); + } + + public AssemblyDef CopyTo(AssemblyDef asm) { + asm.HashAlgorithm = this.HashAlgorithm; + asm.Version = this.Version; + asm.Attributes = this.Attributes; + asm.PublicKey = this.PublicKey; + asm.Name = this.Name ?? UTF8String.Empty; + asm.Culture = this.Culture; + asm.CustomAttributes.Clear(); + asm.CustomAttributes.AddRange(CustomAttributes); + asm.DeclSecurities.Clear(); + asm.DeclSecurities.AddRange(DeclSecurities); + return asm; + } + + public AssemblyDef CreateAssemblyDef(ModuleDef ownerModule) { + return ownerModule.UpdateRowId(CopyTo(new AssemblyDefUser())); + } + + public static AssemblyOptions Create(string name) { + return new AssemblyOptions { + HashAlgorithm = AssemblyHashAlgorithm.SHA1, + Version = new Version(0, 0, 0, 0), + Attributes = AssemblyAttributes.None, + PublicKey = new PublicKey(new byte[0]), + Name = name, + Culture = string.Empty, + ClrVersion = Module.ClrVersion.DefaultVersion, + }; + } + } +} diff --git a/Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptionsDlg.xaml b/Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptionsDlg.xaml new file mode 100644 index 000000000..1cb99fe71 --- /dev/null +++ b/Plugins/dnSpy.AsmEditor/Assembly/AssemblyOptionsDlg.xaml @@ -0,0 +1,179 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +