| // Copyright (c) 2021, Compiler Explorer Authors |
| // All rights reserved. |
| // |
| // Redistribution and use in source and binary forms, with or without |
| // modification, are permitted provided that the following conditions are met: |
| // |
| // * Redistributions of source code must retain the above copyright notice, |
| // this list of conditions and the following disclaimer. |
| // * Redistributions in binary form must reproduce the above copyright |
| // notice, this list of conditions and the following disclaimer in the |
| // documentation and/or other materials provided with the distribution. |
| // |
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE |
| // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| // POSSIBILITY OF SUCH DAMAGE. |
| |
| import {ParseFiltersAndOutputOptions} from '../types/features/filters.interfaces.js'; |
| import {GccDumpViewState} from './panes/gccdump-view.interfaces.js'; |
| |
| import { |
| EmptyCompilerState, |
| ComponentConfig, |
| PopulatedCompilerState, |
| CompilerForTreeState, |
| EmptyExecutorState, |
| PopulatedExecutorState, |
| ExecutorForTreeState, |
| EmptyEditorState, |
| PopulatedEditorState, |
| EmptyTreeState, |
| OutputState, |
| ToolViewState, |
| EmptyToolInputViewState, |
| PopulatedToolInputViewState, |
| PopulatedOptViewState, |
| EmptyOptViewState, |
| EmptyFlagsViewState, |
| PopulatedFlagsViewState, |
| EmptyDiffViewState, |
| PopulatedDiffViewState, |
| EmptyPpViewState, |
| PopulatedPpViewState, |
| EmptyAstViewState, |
| PopulatedAstViewState, |
| EmptyGccDumpViewState, |
| PopulatedGccDumpViewState, |
| EmptyCfgViewState, |
| PopulatedCfgViewState, |
| PopulatedConformanceViewState, |
| EmptyIrViewState, |
| PopulatedIrViewState, |
| EmptyRustMirViewState, |
| PopulatedRustMirViewState, |
| EmptyHaskellCoreViewState, |
| PopulatedHaskellCoreViewState, |
| EmptyHaskellStgViewState, |
| PopulatedHaskellStgViewState, |
| EmptyHaskellCmmViewState, |
| PopulatedHaskellCmmViewState, |
| EmptyGnatDebugTreeViewState, |
| PopulatedGnatDebugTreeViewState, |
| EmptyGnatDebugViewState, |
| PopulatedGnatDebugViewState, |
| EmptyRustMacroExpViewState, |
| PopulatedRustMacroExpViewState, |
| EmptyRustHirViewState, |
| PopulatedRustHirViewState, |
| EmptyDeviceViewState, |
| PopulatedDeviceViewState, |
| COMPILER_COMPONENT_NAME, |
| EXECUTOR_COMPONENT_NAME, |
| EDITOR_COMPONENT_NAME, |
| TREE_COMPONENT_NAME, |
| OUTPUT_COMPONENT_NAME, |
| TOOL_COMPONENT_NAME, |
| TOOL_INPUT_VIEW_COMPONENT_NAME, |
| DIFF_VIEW_COMPONENT_NAME, |
| OPT_VIEW_COMPONENT_NAME, |
| FLAGS_VIEW_COMPONENT_NAME, |
| PP_VIEW_COMPONENT_NAME, |
| AST_VIEW_COMPONENT_NAME, |
| GCC_DUMP_VIEW_COMPONENT_NAME, |
| CFG_VIEW_COMPONENT_NAME, |
| CONFORMANCE_VIEW_COMPONENT_NAME, |
| IR_VIEW_COMPONENT_NAME, |
| RUST_MIR_VIEW_COMPONENT_NAME, |
| HASKELL_CORE_VIEW_COMPONENT_NAME, |
| HASKELL_STG_VIEW_COMPONENT_NAME, |
| HASKELL_CMM_VIEW_COMPONENT_NAME, |
| GNAT_DEBUG_TREE_VIEW_COMPONENT_NAME, |
| GNAT_DEBUG_VIEW_COMPONENT_NAME, |
| RUST_MACRO_EXP_VIEW_COMPONENT_NAME, |
| RUST_HIR_VIEW_COMPONENT_NAME, |
| DEVICE_VIEW_COMPONENT_NAME, |
| LLVM_OPT_PIPELINE_VIEW_COMPONENT_NAME, |
| EmptyLLVMOptPipelineViewState, |
| PopulatedLLVMOptPipelineViewState, |
| } from './components.interfaces.js'; |
| |
| /** Get an empty compiler component. */ |
| export function getCompiler(editorId: number, lang: string): ComponentConfig<EmptyCompilerState> { |
| return { |
| type: 'component', |
| componentName: COMPILER_COMPONENT_NAME, |
| componentState: { |
| source: editorId, |
| lang, |
| }, |
| }; |
| } |
| |
| /** |
| * Get a compiler component with the given configuration. |
| * |
| * We have legacy calls in the codebase (to keep shortlinks permanent) that use this function without |
| * passing langId and libs. To keep that support, the parameters are optional. |
| * |
| * TODO: Find the right type for options |
| */ |
| export function getCompilerWith( |
| editorId: number, |
| filters: ParseFiltersAndOutputOptions | undefined, |
| options: unknown, |
| compilerId: string, |
| langId?: string, |
| libs?: unknown, |
| ): ComponentConfig<PopulatedCompilerState> { |
| return { |
| type: 'component', |
| componentName: COMPILER_COMPONENT_NAME, |
| componentState: { |
| source: editorId, |
| compiler: compilerId, |
| lang: langId, |
| filters, |
| options, |
| libs, |
| }, |
| }; |
| } |
| |
| /** Get a compiler for a tree mode component. */ |
| export function getCompilerForTree(treeId: number, lang: string): ComponentConfig<CompilerForTreeState> { |
| return { |
| type: 'component', |
| componentName: COMPILER_COMPONENT_NAME, |
| componentState: { |
| tree: treeId, |
| lang, |
| }, |
| }; |
| } |
| |
| /** Get an empty executor component. */ |
| export function getExecutor(editorId: number, lang: string): ComponentConfig<EmptyExecutorState> { |
| return { |
| type: 'component', |
| componentName: EXECUTOR_COMPONENT_NAME, |
| componentState: { |
| source: editorId, |
| lang, |
| compilationPanelShown: true, |
| compilerOutShown: true, |
| }, |
| }; |
| } |
| |
| /** Get a compiler component with the given configuration. */ |
| export function getExecutorWith( |
| editorId: number, |
| lang: string, |
| compilerId: string, |
| libraries: unknown, |
| compilerArgs, |
| treeId: number, |
| ): ComponentConfig<PopulatedExecutorState> { |
| return { |
| type: 'component', |
| componentName: EXECUTOR_COMPONENT_NAME, |
| componentState: { |
| source: editorId, |
| tree: treeId, |
| compiler: compilerId, |
| libs: libraries, |
| options: compilerArgs, |
| lang, |
| compilationPanelShown: true, |
| compilerOutShown: true, |
| }, |
| }; |
| } |
| |
| /** Get an executor for a tree mode component. */ |
| export function getExecutorForTree(treeId: number, lang: string): ComponentConfig<ExecutorForTreeState> { |
| return { |
| type: 'component', |
| componentName: EXECUTOR_COMPONENT_NAME, |
| componentState: { |
| tree: treeId, |
| lang, |
| compilationPanelShown: true, |
| compilerOutShown: true, |
| }, |
| }; |
| } |
| |
| /** |
| * Get an empty editor component. |
| * |
| * TODO: main.js calls this with no arguments. |
| */ |
| export function getEditor(langId: string, id?: number): ComponentConfig<EmptyEditorState> { |
| return { |
| type: 'component', |
| componentName: EDITOR_COMPONENT_NAME, |
| componentState: { |
| id, |
| lang: langId, |
| }, |
| }; |
| } |
| |
| /** Get an editor component with the given configuration. */ |
| export function getEditorWith( |
| id: number, |
| source: string, |
| options: ParseFiltersAndOutputOptions, |
| langId: string, |
| ): ComponentConfig<PopulatedEditorState> { |
| return { |
| type: 'component', |
| componentName: EDITOR_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| options, |
| lang: langId, |
| }, |
| }; |
| } |
| |
| /** |
| * Get an empty tree component. |
| * |
| * TODO: main.js calls this with no arguments. |
| */ |
| export function getTree(id?: number): ComponentConfig<EmptyTreeState> { |
| return { |
| type: 'component', |
| componentName: TREE_COMPONENT_NAME, |
| componentState: { |
| id, |
| cmakeArgs: '-DCMAKE_BUILD_TYPE=Debug', |
| }, |
| }; |
| } |
| |
| /** Get an output component with the given configuration. */ |
| export function getOutput(compiler: number, editor: number, tree: number): ComponentConfig<OutputState> { |
| return { |
| type: 'component', |
| componentName: OUTPUT_COMPONENT_NAME, |
| componentState: { |
| compiler, |
| editor, |
| tree, |
| }, |
| }; |
| } |
| |
| /** Get a tool view component with the given configuration. */ |
| export function getToolViewWith( |
| compilerId: number, |
| compilerName: string, |
| editorid: number, |
| toolId: string, |
| args: string, |
| monacoStdin: boolean, |
| tree: number, |
| ): ComponentConfig<ToolViewState> { |
| return { |
| type: 'component', |
| componentName: TOOL_COMPONENT_NAME, |
| componentState: { |
| id: compilerId, |
| compilerName, |
| editorid, |
| toolId, |
| args, |
| tree, |
| monacoStdin, |
| }, |
| }; |
| } |
| |
| /** Get an empty tool input view component. */ |
| export function getToolInputView(): ComponentConfig<EmptyToolInputViewState> { |
| return { |
| type: 'component', |
| componentName: TOOL_INPUT_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a tool input view component with the given configuration. */ |
| export function getToolInputViewWith( |
| compilerId: number, |
| toolId: string, |
| toolName: string, |
| ): ComponentConfig<PopulatedToolInputViewState> { |
| return { |
| type: 'component', |
| componentName: TOOL_INPUT_VIEW_COMPONENT_NAME, |
| componentState: { |
| compilerId, |
| toolId, |
| toolName, |
| }, |
| }; |
| } |
| |
| /** Get an empty diff component. */ |
| export function getDiffView(): ComponentConfig<EmptyDiffViewState> { |
| return { |
| type: 'component', |
| componentName: DIFF_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** |
| * Get a diff component with the given configuration. |
| * |
| * TODO: possibly unused? |
| */ |
| export function getDiffViewWith(lhs: unknown, rhs: unknown): ComponentConfig<PopulatedDiffViewState> { |
| return { |
| type: 'component', |
| componentName: DIFF_VIEW_COMPONENT_NAME, |
| componentState: { |
| lhs, |
| rhs, |
| }, |
| }; |
| } |
| |
| /** Get an empty opt view component. */ |
| export function getOptView(): ComponentConfig<EmptyOptViewState> { |
| return { |
| type: 'component', |
| componentName: OPT_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get an opt view with the given configuration. */ |
| export function getOptViewWith( |
| id: number, |
| source: string, |
| optOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedOptViewState> { |
| return { |
| type: 'component', |
| componentName: OPT_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| optOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty flags view component. */ |
| export function getFlagsView(): ComponentConfig<EmptyFlagsViewState> { |
| return { |
| type: 'component', |
| componentName: FLAGS_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a flags view with the given configuration. */ |
| export function getFlagsViewWith( |
| id: number, |
| compilerName: string, |
| compilerFlags: unknown, |
| ): ComponentConfig<PopulatedFlagsViewState> { |
| return { |
| type: 'component', |
| componentName: FLAGS_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| compilerName, |
| compilerFlags, |
| }, |
| }; |
| } |
| |
| /** Get an empty preprocessor view component. */ |
| export function getPpView(): ComponentConfig<EmptyPpViewState> { |
| return { |
| type: 'component', |
| componentName: PP_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a preprocessor view with the given configuration. */ |
| export function getPpViewWith( |
| id: number, |
| source: string, |
| ppOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedPpViewState> { |
| return { |
| type: 'component', |
| componentName: PP_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| ppOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty ast view component. */ |
| export function getAstView(): ComponentConfig<EmptyAstViewState> { |
| return { |
| type: 'component', |
| componentName: AST_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get an ast view with the given configuration. */ |
| export function getAstViewWith( |
| id: number, |
| source: string, |
| astOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedAstViewState> { |
| return { |
| type: 'component', |
| componentName: AST_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| astOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty gcc dump view component. */ |
| export function getGccDumpView(): ComponentConfig<EmptyGccDumpViewState> { |
| return { |
| type: 'component', |
| componentName: GCC_DUMP_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a gcc dump view with the given configuration. */ |
| export function getGccDumpViewWith( |
| id: number, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| gccDumpOutput: GccDumpViewState, |
| ): ComponentConfig<PopulatedGccDumpViewState> { |
| return { |
| type: 'component', |
| componentName: GCC_DUMP_VIEW_COMPONENT_NAME, |
| componentState: { |
| // PopulatedGccDumpViewState |
| id, |
| compilerName, |
| editorid, |
| treeid, |
| |
| // & GccDumpFiltersState |
| ...gccDumpOutput, |
| }, |
| }; |
| } |
| |
| /** Get an empty cfg view component. */ |
| export function getCfgView(): ComponentConfig<EmptyCfgViewState> { |
| return { |
| type: 'component', |
| componentName: CFG_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a cfg view with the given configuration. */ |
| export function getCfgViewWith(id: number, editorid: number, treeid: number): ComponentConfig<PopulatedCfgViewState> { |
| return { |
| type: 'component', |
| componentName: CFG_VIEW_COMPONENT_NAME, |
| componentState: { |
| selectedFunction: null, |
| zoom: 1, |
| id, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get a conformance view with the given configuration. */ |
| export function getConformanceView( |
| editorid: number, |
| treeid: number, |
| source: string, |
| langId: string, |
| ): ComponentConfig<PopulatedConformanceViewState> { |
| return { |
| type: 'component', |
| componentName: CONFORMANCE_VIEW_COMPONENT_NAME, |
| componentState: { |
| editorid, |
| treeid, |
| source, |
| langId, |
| }, |
| }; |
| } |
| |
| /** Get an empty ir view component. */ |
| export function getIrView(): ComponentConfig<EmptyIrViewState> { |
| return { |
| type: 'component', |
| componentName: IR_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a ir view with the given configuration. */ |
| export function getIrViewWith( |
| id: number, |
| source: string, |
| irOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedIrViewState> { |
| return { |
| type: 'component', |
| componentName: IR_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| irOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty ir view component. */ |
| export function getLLVMOptPipelineView(): ComponentConfig<EmptyLLVMOptPipelineViewState> { |
| return { |
| type: 'component', |
| componentName: LLVM_OPT_PIPELINE_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a ir view with the given configuration. */ |
| export function getLLVMOptPipelineViewWith( |
| id: number, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedLLVMOptPipelineViewState> { |
| return { |
| type: 'component', |
| componentName: LLVM_OPT_PIPELINE_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| compilerName, |
| editorid, |
| treeid, |
| selectedFunction: '', |
| selectedIndex: 0, |
| sidebarWidth: 0, |
| }, |
| }; |
| } |
| |
| /** Get an empty rust mir view component. */ |
| export function getRustMirView(): ComponentConfig<EmptyRustMirViewState> { |
| return { |
| type: 'component', |
| componentName: RUST_MIR_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a rust mir view with the given configuration. */ |
| export function getRustMirViewWith( |
| id: number, |
| source: string, |
| rustMirOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedRustMirViewState> { |
| return { |
| type: 'component', |
| componentName: RUST_MIR_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| rustMirOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty haskell core view component. */ |
| export function getHaskellCoreView(): ComponentConfig<EmptyHaskellCoreViewState> { |
| return { |
| type: 'component', |
| componentName: HASKELL_CORE_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a haskell core view with the given configuration. */ |
| export function getHaskellCoreViewWith( |
| id: number, |
| source: string, |
| haskellCoreOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedHaskellCoreViewState> { |
| return { |
| type: 'component', |
| componentName: HASKELL_CORE_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| haskellCoreOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty haskell stg view component. */ |
| export function getHaskellStgView(): ComponentConfig<EmptyHaskellStgViewState> { |
| return { |
| type: 'component', |
| componentName: HASKELL_STG_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a haskell stg view with the given configuration. */ |
| export function getHaskellStgViewWith( |
| id: number, |
| source: string, |
| haskellStgOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedHaskellStgViewState> { |
| return { |
| type: 'component', |
| componentName: HASKELL_STG_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| haskellStgOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty haskell cmm view component. */ |
| export function getHaskellCmmView(): ComponentConfig<EmptyHaskellCmmViewState> { |
| return { |
| type: 'component', |
| componentName: HASKELL_CMM_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| export function getHaskellCmmViewWith( |
| id: number, |
| source: string, |
| haskellCmmOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedHaskellCmmViewState> { |
| return { |
| type: 'component', |
| componentName: HASKELL_CMM_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| haskellCmmOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty gnat debug tree view component. */ |
| export function getGnatDebugTreeView(): ComponentConfig<EmptyGnatDebugTreeViewState> { |
| return { |
| type: 'component', |
| componentName: GNAT_DEBUG_TREE_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a gnat debug tree view with the given configuration. */ |
| export function getGnatDebugTreeViewWith( |
| id: number, |
| source: string, |
| gnatDebugTreeOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedGnatDebugTreeViewState> { |
| return { |
| type: 'component', |
| componentName: GNAT_DEBUG_TREE_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| gnatDebugTreeOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty gnat debug info view component. */ |
| export function getGnatDebugView(): ComponentConfig<EmptyGnatDebugViewState> { |
| return { |
| type: 'component', |
| componentName: GNAT_DEBUG_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a gnat debug info view with the given configuration. */ |
| export function getGnatDebugViewWith( |
| id: number, |
| source: string, |
| gnatDebugOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedGnatDebugViewState> { |
| return { |
| type: 'component', |
| componentName: GNAT_DEBUG_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| gnatDebugOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty rust macro exp view component. */ |
| export function getRustMacroExpView(): ComponentConfig<EmptyRustMacroExpViewState> { |
| return { |
| type: 'component', |
| componentName: RUST_MACRO_EXP_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a rust macro exp view with the given configuration. */ |
| export function getRustMacroExpViewWith( |
| id: number, |
| source: string, |
| rustMacroExpOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedRustMacroExpViewState> { |
| return { |
| type: 'component', |
| componentName: RUST_MACRO_EXP_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| rustMacroExpOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty rust hir view component. */ |
| export function getRustHirView(): ComponentConfig<EmptyRustHirViewState> { |
| return { |
| type: 'component', |
| componentName: RUST_HIR_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a rust hir view with the given configuration. */ |
| export function getRustHirViewWith( |
| id: number, |
| source: string, |
| rustHirOutput: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedRustHirViewState> { |
| return { |
| type: 'component', |
| componentName: RUST_HIR_VIEW_COMPONENT_NAME, |
| componentState: { |
| id, |
| source, |
| rustHirOutput, |
| compilerName, |
| editorid, |
| treeid, |
| }, |
| }; |
| } |
| |
| /** Get an empty device view component. */ |
| export function getDeviceView(): ComponentConfig<EmptyDeviceViewState> { |
| return { |
| type: 'component', |
| componentName: DEVICE_VIEW_COMPONENT_NAME, |
| componentState: {}, |
| }; |
| } |
| |
| /** Get a device view with the given configuration. */ |
| export function getDeviceViewWith( |
| id: number, |
| source: string, |
| devices: unknown, |
| compilerName: string, |
| editorid: number, |
| treeid: number, |
| ): ComponentConfig<PopulatedDeviceViewState> { |
| return { |
| type: 'component', |
| componentName: DEVICE_VIEW_COMPONENT_NAME, |
| componentState: { |
| id: id, |
| source: source, |
| devices: devices, |
| compilerName: compilerName, |
| editorid: editorid, |
| treeid: treeid, |
| }, |
| }; |
| } |