blob: dcc467948bbfd6f0d2d64e7812fd191e60bd3901 [file] [log] [blame] [raw]
// Copyright (c) 2022, 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 {ParsedAsmResult} from '../../types/asmresult/asmresult.interfaces';
import {CompilationResult} from '../../types/compilation/compilation.interfaces';
import {PreliminaryCompilerInfo} from '../../types/compiler.interfaces';
import {ParseFiltersAndOutputOptions} from '../../types/features/filters.interfaces';
import {ResultLine} from '../../types/resultline/resultline.interfaces';
import {unwrap} from '../assert';
import {BaseCompiler} from '../base-compiler';
import {BaseParser} from './argument-parsers';
export class CarbonCompiler extends BaseCompiler {
static get key() {
return 'carbon';
}
constructor(compilerInfo: PreliminaryCompilerInfo, env) {
super(compilerInfo, env);
this.compiler.demangler = '';
this.demanglerClass = null;
}
override optionsForFilter(filters: ParseFiltersAndOutputOptions, outputFilename: string): string[] {
return ['--color', `--trace_file=${outputFilename}`];
}
override processAsm(result, filters, options): ParsedAsmResult {
// Really should write a custom parser, but for now just don't filter anything.
return super.processAsm(
result,
{
labels: false,
binary: false,
commentOnly: false,
demangle: false,
optOutput: false,
directives: false,
dontMaskFilenames: false,
execute: false,
intel: false,
libraryCode: false,
trim: false,
},
options,
);
}
lastLine(lines?: ResultLine[]): string {
if (!lines || lines.length === 0) return '';
return unwrap(lines.at(-1)).text;
}
override postCompilationPreCacheHook(result: CompilationResult): CompilationResult {
if (result.code === 0) {
// Hook to parse out the "result: 123" line at the end of the interpreted execution run.
const re = /^result: (\d+)$/;
const match = re.exec(this.lastLine(result.asm));
const code = match ? parseInt(match[1]) : -1;
result.execResult = {
stdout: result.stdout,
stderr: [],
code: code,
didExecute: true,
buildResult: {
code: 0,
timedOut: false,
stdout: [],
stderr: [],
downloads: [],
executableFilename: '',
compilationOptions: [],
},
};
result.stdout = [];
}
return result;
}
override getArgumentParser() {
// TODO: may need a custom one, based on/borrowing from ClangParser
return BaseParser;
}
}