blob: 82d70918f447f7478b1cee44025e203200727db5 [file] [log] [blame] [raw]
// 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,
},
};
}