- Kompilator
- Arduino
- C (bahasa pemrograman)
- DeepSeek
- Perangkat lunak gratis
- Swift (bahasa pemrograman)
- React.js
- Java
- Pemrograman
- Dalvik (perangkat lunak)
- Source-to-source compiler
- Free and open-source software
- Open source
- List of compilers
- Compiler-compiler
- Compiler
- Source code
- Source (game engine)
- Cross compiler
- Source Mage
Jean de Florette (1986)
Exte: Hair Extensions (2007)
Tears of No Regret (2020)
To Be or Not to Be (1983)
Source-to-source compiler GudangMovies21 Rebahinxxi LK21
A source" target="_blank">source-to-source" target="_blank">source translator, source" target="_blank">source-to-source" target="_blank">source compiler (S2S compiler), transcompiler, or transpiler is a type of translator that takes the source" target="_blank">source code of a program written in a programming language as its input and produces an equivalent source" target="_blank">source code in the same or a different programming language. A source" target="_blank">source-to-source" target="_blank">source translator converts between programming languages that operate at approximately the same level of abstraction, while a traditional compiler translates from a higher level programming language to a lower level programming language. For example, a source" target="_blank">source-to-source" target="_blank">source translator may perform a translation of a program from Python to JavaScript, while a traditional compiler translates from a language like C to assembly or Java to bytecode. An automatic parallelizing compiler will frequently take in a high level language program as an input and then transform the code and annotate it with parallel code annotations (e.g., OpenMP) or language constructs (e.g. Fortran's forall statements).
Another purpose of source" target="_blank">source-to-source" target="_blank">source-compiling is translating legacy code to use the next version of the underlying programming language or an API that breaks backward compatibility. It will perform automatic code refactoring which is useful when the programs to refactor are outside the control of the original implementer (for example, converting programs from Python 2 to Python 3, or converting programs from an old API to the new API) or when the size of the program makes it impractical or time-consuming to refactor it by hand.
Transcompilers may either keep translated code structure as close to the source" target="_blank">source code as possible to ease development and debugging of the original source" target="_blank">source code or may change the structure of the original code so much that the translated code does not look like the source" target="_blank">source code. There are also debugging utilities that map the transcompiled source" target="_blank">source code back to the original code; for example, the JavaScript source" target="_blank">Source Map standard allows mapping of the JavaScript code executed by a web browser back to the original source" target="_blank">source when the JavaScript code was, for example, minified or produced by a transcompiled-to-JavaScript language.
Examples include Closure Compiler, CoffeeScript, Dart, Haxe, Opal, TypeScript and Emscripten.
Assembly language translators
So called Assembly language translators are a class of source" target="_blank">source-to-source" target="_blank">source translators converting code from one assembly language into another, including (but not limited to) across different processor families and system platforms.
= Intel CONV86
=Intel marketed their 16-bit processor 8086 to be source" target="_blank">source compatible to the 8080, an 8-bit processor. To support this, Intel had an ISIS-II-based translator from 8080 to 8086 source" target="_blank">source code named CONV86 (also referred to as CONV-86 and CONVERT 86) available to OEM customers since 1978, possibly the earliest program of this kind. It supported multiple levels of translation and ran at 2 MHz on an Intel Microprocessor Development System MDS-800 with 8-inch floppy drives. According to user reports, it did not work very reliably.
= SCP TRANS86
=Seattle Computer Products (SCP) offered TRANS86.COM, written by Tim Paterson in 1980 while developing 86-DOS. The utility could translate Intel 8080 and Zilog Z80 assembly source" target="_blank">source code (with Zilog/Mostek mnemonics) into .ASM source" target="_blank">source code for the Intel 8086 (in a format only compatible with SCP's cross-assembler ASM86 for CP/M-80), but supported only a subset of opcodes, registers and modes, and often still required significant manual correction and rework afterwards. Also, performing only a mere transliteration, the brute-force single-pass translator did not carry out any register and jump optimizations. It took about 24 KB of RAM. The SCP version 1 of TRANS86.COM ran on Z80-based systems. Once 86-DOS was running, Paterson, in a self-hosting-inspired approach, utilized TRANS86 to convert itself into a program running under 86-DOS. Numbered version 2, this was named TRANS.COM instead. Later in 1982, the translator was apparently also available from Microsoft.
= Sorcim TRANS86
=Also named TRANS86, Sorcim offered an 8080 to 8086 translator as well since December 1980. Like SCP's program it was designed to port CP/M-80 application code (in ASM, MAC, RMAC or ACT80 assembly format) to MS-DOS (in a format compatible with ACT86). In ACT80 format it also supported a few Z80 mnemonics. The translation occurred on an instruction-by-instruction basis with some optimization applied to conditional jumps. The program ran under CP/M-80, MP/M-80 and Cromemco DOS with a minimum of 24 KB of RAM, and had no restrictions on the source" target="_blank">source file size.
= Digital Research XLT86
=Much more sophisticated and the first to introduce optimizing compiler technologies into the source" target="_blank">source translation process was Digital Research's XLT86 1.0 in September 1981. XLT86 1.1 was available by April 1982. The program was written by Gary Kildall and translated .ASM source" target="_blank">source code for the Intel 8080 processor (in a format compatible with ASM, MAC or RMAC assemblers) into .A86 source" target="_blank">source code for the 8086 (compatible with ASM86). Using global data flow analysis on 8080 register usage, the five-phase multi-pass translator would also optimize the output for code size and take care of calling conventions (CP/M-80 BDOS calls were mapped into BDOS calls for CP/M-86), so that CP/M-80 and MP/M-80 programs could be ported to the CP/M-86 and MP/M-86 platforms automatically. XLT86.COM itself was written in PL/I-80 for CP/M-80 platforms. The program occupied 30 KB of RAM for itself plus additional memory for the program graph. On a 64 KB memory system, the maximum source" target="_blank">source file size supported was about 6 KB, so that larger files had to be broken down accordingly before translation. Alternatively, XLT86 was also available for DEC VAX/VMS. Although XLT86's input and output worked on source" target="_blank">source-code level, the translator's in-memory representation of the program and the applied code optimizing technologies set the foundation to binary recompilation.
= Others
=2500 AD Software offered an 8080 to 8086 source" target="_blank">source-code translator as part of their XASM suite for CP/M-80 machines with Z80 as well as for Zilog ZEUS and Olivetti PCOS systems.
Since 1979, Zilog offered a Z80 to Z8000 translator as part of their PDS 8000 development system. Advanced Micro Computers (AMC) and 2500 AD Software offered Z80 to Z8000 translators as well. The latter was named TRANS and was available for Z80 CP/M, CP/M-86, MS-DOS and PCOS.
The Z88DK development kit provides a Z80 to i486 source" target="_blank">source code translator targeting nasm named "to86.awk", written in 2008 by Stefano Bodrato. It is in turn based on an 8080 to Z80 converter written in 2003 by Douglas Beattie, Jr., named "toz80.awk".
In 2021, Brian Callahan wrote an 8080 CP/M 2.2 to MS-DOS source" target="_blank">source code translator targeting nasm named 8088ify.
Programming language implementations
The first implementations of some programming languages started as transcompilers, and the default implementation for some of those languages are still transcompilers. In addition to the table below, a CoffeeScript maintainer provides a list of languages that compile to JavaScript.
Porting a codebase
When developers want to switch to a different language while retaining most of an existing codebase, it might be better to use a transcompiler compared to rewriting the whole software by hand. Depending on the quality of the transcompiler, the code may or may not need manual intervention in order to work properly. This is different from "transcompiled languages" where the specifications demand that the output source" target="_blank">source code always works without modification. All transcompilers used to port a codebase will expect manual adjustment of the output source" target="_blank">source code if there is a need to achieve maximum code quality in terms of readability and platform convention.
Transcompiler pipelines
A transcompiler pipeline is what results from recursive transcompiling. By stringing together multiple layers of tech, with a transcompile step between each layer, technology can be repeatedly transformed, effectively creating a distributed language independent specification.
XSLT is a general-purpose transform tool that can be used between many different technologies, to create such a derivative code pipeline.
= Recursive transcompiling
=Recursive transcompilation (or recursive transpiling) is the process of applying the notion of transcompiling recursively, to create a pipeline of transformations (often starting from a single source" target="_blank">source of truth) which repeatedly turn one technology into another.
By repeating this process, one can turn A → B → C → D → E → F and then back into A(v2). Some information will be preserved through this pipeline, from A → A(v2), and that information (at an abstract level) demonstrates what each of the components A–F agree on.
In each of the different versions that the transcompiler pipeline produces, that information is preserved. It might take on many different shapes and sizes, but by the time it comes back to A (v2), having been transcompiled six times in the pipeline above, the information returns to its original state.
This information which survives the transform through each format, from A–F–A(v2), is (by definition) derivative content or derivative code.
Recursive transcompilation takes advantage of the fact that transcompilers may either keep translated code as close to the source" target="_blank">source code as possible to ease development and debugging of the original source" target="_blank">source code, or else they may change the structure of the original code so much, that the translated code does not look like the source" target="_blank">source code. There are also debugging utilities that map the transcompiled source" target="_blank">source code back to the original code; for example, JavaScript source" target="_blank">source maps allow mapping of the JavaScript code executed by a web browser back to the original source" target="_blank">source in a transcompiled-to-JavaScript language.
See also
Notes
References
Further reading
Britten, Charles Randyl (2020-06-26). "Translation of 8080 Code to 8086 - Microsoft Translation of 8080 Code to 8086 and Other 16-Bit Processors". Archived from the original on 2021-07-23. Retrieved 2021-11-28.
"Programming of Sycor Units Eased With TAL II". Computerworld – The Newsweekly for the Computer Community. Vol. IX, no. 34. Ann Arbor, Michigan, USA: Computerworld, Inc. 1975-08-20. p. 14. ISSN 0010-4841. Archived from the original on 2020-02-01. Retrieved 2020-01-18.
Zerilli, Frank J.; Derouen, Craig (1986-12-11) [1985-08-15, 1984-12-20, 1984-11-20]. "8080 to 8086 ASM translator, with ASM source" target="_blank">source". SIMTEL. XLT86.COM 1.10. Archived from the original on 2020-02-01. Retrieved 2020-01-18. 1984-11-11 version 1.05 (NB. The DOS executable XLT86.COM [12 KB] translates Intel 8080 assembly language source" target="_blank">source code to Intel 8086 assembly language source" target="_blank">source code. Despite its name this implementation in 8086 assembly is not related to Digital Research's earlier and much more sophisticated XLT86.)
Albo, Julián (2009-04-24). "Pasmo, ensamblador cruzado Z80 portable / portable Z80 cross assembler" (in Spanish and English). Archived from the original on 2020-02-20. Retrieved 2020-02-20. […] Pasmo is a Z80 cross assembler […] that […] can generate object code in the following formats: raw binary, Intel HEX, PRL for CP/M Plus RSX, Plus3Dos (Spectrum +3 disk), TAP, TZX and CDT (Spectrum and Amstrad CPC emulators tape images), AmsDos (Amstrad CPC disk) and MSX (for use with BLOAD from disk in Basic). Starting with version 0.5.0 […] can also generate 8086 code from Z80 sources, in binary format for Ms-dos COM files or in CP/M 86 CMD format. […] [42] [43]
Ciarcia, Steve (May 1984). "Trump Card – Part 1: Hardware – Speed up your IBM PC with 16-bit coprocessing power" (PDF). BYTE – The small systems journal. Ciarcia's Circuit Cellar. Vol. 9, no. 5. McGraw-Hill, Inc. pp. 40–52, 54–55. ISSN 0360-5280. Retrieved 2020-01-29. […] It instead executes programs written in high-level languages such as BASIC and C (a Pascal compiler and a 8088 to Z8000 translator are in the works. […] and Ciarcia, Steve (June 1984). "Trump Card – Part 2: Software – TBASIC and C compilers and an assemble" (PDF). BYTE – The small systems journal. Ciarcia's Circuit Cellar. Vol. 9, no. 6. McGraw-Hill, Inc. pp. 115–122. ISSN 0360-5280. Retrieved 2020-01-29. […] I expect that object-code translators for Z80-to-Z8000 and 8088-to-Z8000 conversions will soon be available […], also available as Ciarcia, Steve (1990). "Trump Card – Part 1: Hardware – Speed up your IBM PC with 16-bit coprocessing power & Part 2: Software – TBASIC and C compilers and an assemble". In Gonneau, Daniel; Bernardi, Fred; Ausburn, Richard (eds.). Ciarcia's Circuit Cellar. Vol. 7. McGraw-Hill Publishing Company. pp. 138–152, 153–160. ISBN 0-07-010969-9. Archived from the original on 2020-02-01. Retrieved 2020-01-29. [44][usurped]
Microcontroller Division Application Team (2000). "Translating Assembly Code From HC05 To ST7" (PDF) (Application Note). STMicroelectronics. AN1106/0200. Retrieved 2020-01-18. (9 pages) (NB. This software translator was developed by ST and translates Motorola 6805/HC05 assembly source" target="_blank">source code in 2500AD Software format into ST7 source" target="_blank">source code. The MIGR2ST7.EXE executable for Windows is available from "MCU ON CD".)
Kuper, Lindsey (2017-07-30). "What do people mean when they say "transpiler"?". language implementation. composition.al. Archived from the original on 2022-01-09. Retrieved 2022-01-09.
External links
Chaudry, Gabriele "Gaby" (2009-07-11). "Das Intel zu Zilog – Übersetzungsprojekt". I2Z-Translator (in German). Archived from the original on 2016-09-11. Retrieved 2020-01-18.
"PortAsm Assembler to Assembler Translation". MicroAPL Ltd. 2017 [1996]. Archived from the original on 2019-07-30. Retrieved 2020-01-18.
"Our Methodology – The source" target="_blank">Source to source" target="_blank">Source Conversion Process". Micro-Processor Services, Inc. (MPS). Archived from the original on 2019-05-12. Retrieved 2020-02-01.
Kata Kunci Pencarian:
Extending A Source To Source Compiler | PDF | Xslt | X Path
GitHub - askevis/Source-to-source-Compiler: A Source-to-source compiler ...
data:image/s3,"s3://crabby-images/a49e3/a49e342f577bb071218f10e5c584b317ed205dad" alt="Source-to-Source Compiler | PDF"
Source-to-Source Compiler | PDF
data:image/s3,"s3://crabby-images/b3e9e/b3e9e97120df39cd87a60e89e93d5b2f5d6b9fea" alt="Source-to-Source Compiler | PDF"
Source-to-Source Compiler | PDF
data:image/s3,"s3://crabby-images/a7240/a72408d5ecfdc297e2ce971f5a19a76f9169b154" alt="Source-to-source compiler | Semantic Scholar"
Source-to-source compiler | Semantic Scholar
data:image/s3,"s3://crabby-images/74b2f/74b2f6a8400798ec3fcb1045f000e9808134a5dd" alt="Source-to-source compiler | Semantic Scholar"
Source-to-source compiler | Semantic Scholar
data:image/s3,"s3://crabby-images/d78af/d78af454620a6ae7cfbbadf3bbc8d2f39b469d32" alt="Source to Source Compiler Graphic by laurenejlevinson · Creative Fabrica"
Source to Source Compiler Graphic by laurenejlevinson · Creative Fabrica
data:image/s3,"s3://crabby-images/93f6a/93f6ad035137c38386489868f37598bdf5ecdccf" alt="Compiler design in c source code - vinosop"
Compiler design in c source code - vinosop
data:image/s3,"s3://crabby-images/13acd/13acdd535f2b19dcc5011d44df30cac8004efcb8" alt="Source to source compiler background hi-res stock photography and ..."
Source to source compiler background hi-res stock photography and ...
data:image/s3,"s3://crabby-images/a4fdb/a4fdb2fe055782c35d62b341aca16c1fd4037c75" alt="Source to source compiler background hi-res stock photography and ..."
Source to source compiler background hi-res stock photography and ...
data:image/s3,"s3://crabby-images/e78df/e78df8fca712a424f2c518271008fe604412d207" alt="PPT - ROSE Compiler Infrastructure Source-to-Source Analysis and ..."
PPT - ROSE Compiler Infrastructure Source-to-Source Analysis and ...
data:image/s3,"s3://crabby-images/08dde/08ddeead17b6d58e846f6d9bcf5ff56ce9bdfec1" alt="At compile time the CPPC source-to-source compiler automatically ..."
At compile time the CPPC source-to-source compiler automatically ...