aboutsummaryrefslogtreecommitdiff
path: root/lib/compilers
diff options
context:
space:
mode:
authorRubén Rincón Blanco <ruben@rinconblanco.es>2022-11-17 15:20:12 +0100
committerGitHub <noreply@github.com>2022-11-17 15:20:12 +0100
commitb67f5cfaa269433e679e36d3f5acdb038e746a11 (patch)
tree211437026738f6f5333973eeacc5932255ff22be /lib/compilers
parentd184d99f37e39b45d584d40140a2cbddbfe05def (diff)
downloadcompiler-explorer-b67f5cfaa269433e679e36d3f5acdb038e746a11.tar.gz
compiler-explorer-b67f5cfaa269433e679e36d3f5acdb038e746a11.zip
Fix Python argument order (#4295)gh-4907
Diffstat (limited to 'lib/compilers')
-rw-r--r--lib/compilers/carbon.js2
-rw-r--r--lib/compilers/python.ts (renamed from lib/compilers/python.js)43
2 files changed, 34 insertions, 11 deletions
diff --git a/lib/compilers/carbon.js b/lib/compilers/carbon.js
index d6c865939..615612cfc 100644
--- a/lib/compilers/carbon.js
+++ b/lib/compilers/carbon.js
@@ -33,7 +33,7 @@ export class CarbonCompiler extends BaseCompiler {
constructor(compilerInfo, env) {
super(compilerInfo, env);
- this.compiler.demangler = null;
+ this.compiler.demangler = '';
this.demanglerClass = null;
}
diff --git a/lib/compilers/python.js b/lib/compilers/python.ts
index 293e100ad..a9a2f2c5a 100644
--- a/lib/compilers/python.js
+++ b/lib/compilers/python.ts
@@ -22,33 +22,35 @@
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
+import {AsmResultSource, ParsedAsmResultLine} from '../../types/asmresult/asmresult.interfaces';
import {BaseCompiler} from '../base-compiler';
import {resolvePathFromAppRoot} from '../utils';
import {BaseParser} from './argument-parsers';
export class PythonCompiler extends BaseCompiler {
+ private readonly disasmScriptPath: string;
+
static get key() {
return 'python';
}
constructor(compilerInfo, env) {
super(compilerInfo, env);
- this.compiler.demangler = null;
+ this.compiler.demangler = '';
this.demanglerClass = null;
this.disasmScriptPath =
this.compilerProps('disasmScript') || resolvePathFromAppRoot('etc', 'scripts', 'disasms', 'dis_all.py');
}
- // eslint-disable-next-line no-unused-vars
- processAsm(result, filters) {
+ override processAsm(result) {
const lineRe = /^\s{0,4}(\d+)(.*)/;
const bytecodeLines = result.asm.split('\n');
- const bytecodeResult = [];
- let lastLineNo = null;
- let sourceLoc = null;
+ const bytecodeResult: ParsedAsmResultLine[] = [];
+ let lastLineNo: number | undefined;
+ let sourceLoc: AsmResultSource | null = null;
for (const line of bytecodeLines) {
const match = line.match(lineRe);
@@ -58,8 +60,8 @@ export class PythonCompiler extends BaseCompiler {
sourceLoc = {line: lineno, file: null};
lastLineNo = lineno;
} else if (!line) {
- sourceLoc = {line: null, file: null};
- lastLineNo = null;
+ sourceLoc = {line: undefined, file: null};
+ lastLineNo = undefined;
} else {
sourceLoc = {line: lastLineNo, file: null};
}
@@ -70,11 +72,32 @@ export class PythonCompiler extends BaseCompiler {
return {asm: bytecodeResult};
}
- optionsForFilter(filters, outputFilename) {
+ override optionsForFilter(filters, outputFilename) {
return ['-I', this.disasmScriptPath, '--outputfile', outputFilename, '--inputfile'];
}
- getArgumentParser() {
+ override getArgumentParser() {
return BaseParser;
}
+
+ override orderArguments(
+ options: string[],
+ inputFilename: string,
+ libIncludes: string[],
+ libOptions: string[],
+ libPaths: string[],
+ libLinks: string[],
+ userOptions: string[],
+ staticLibLinks: string[],
+ ) {
+ return options.concat(
+ [this.filename(inputFilename)],
+ libIncludes,
+ libOptions,
+ libPaths,
+ libLinks,
+ userOptions,
+ staticLibLinks,
+ );
+ }
}