Adam McKenna
Adam McKenna

Reputation: 2435

Is Babel a compiler or transpiler?

I've been using Babel for a while now, and I've always been under the impression that Babel was a transpiler for converting my ES6 and ES7 JavaScript into ES5 JavaScript, as I was under the assumption that you could technically treat ES5 and ES6 as two different language.

However, I couldn't help but notice that Babel's website title describes it as a compiler, which I believe is something very different from a transpiler.

Babel website title - 'Babel - The compiler for writing next generation JavaScript

Is Babel a transpiler or a compiler, or perhaps offers both options? Or is the website's title simply incorrect?

Disclosure: I know this sounds like a very pedantic question, but I am writing documentation relating to Babel, and I want to ensure my description is accurate

Upvotes: 56

Views: 23947

Answers (4)

Chris Kim
Chris Kim

Reputation: 1

Just FYI, 'compiler' is defined as

a program that converts instructions into a machine-code or lower-level form so that they can be read and executed by a computer.

So I personally disagree that Babel is a compiler but I don't really care if others use them interchangeably.

Upvotes: 0

maerics
maerics

Reputation: 156434

Babel is a transpiler, which is a special type of compiler, so both terms are techincally correct. You may use either at your preference.

It's irrefutable that Babel is a source-to-source compiler (aka transpiler) since its source and target languages are both some flavor of JavaScript:

A source-to-source compiler, transcompiler or transpiler is a type of compiler that takes the source code of a program written in one programming language as its input and produces the equivalent source code in another programming language.

However, not everyone agrees that the distinction between the terms is helpful, so some people prefer simply, "compiler".

I personally like the distinction because, to me, it implies something about the difference in level of abstraction from machine langauge between the source (input) and target (output) languages. That is, typical "compilers" translate from higher-to-lower level languages, "decompilers" translate from lower-to-higher level languages, and "transpilers" translate between languages at similar levels of abstraction.

Upvotes: 17

Bergi
Bergi

Reputation: 664503

The definitions of "transpiler" and "compiler" are blurry. Both of them do translate a program from one language to another language while keeping the behaviour.

We usually name it a "compiler" when it produces an executable binary. However, binary is just another language, which can be interpreted by a CPU. Every program is "executable" on the respective machine.

We usually name it a "compiler" when it produces a lower-level output than the input was, e.g. C to assembler. Or Java to Java bytecode. Or ES8 to ES5. Wait… is that really a different level?

We usually name it a "transpiler" when its output is on a similar level as the input, e.g. Python to JavaScript or the other way round. However, there always will be parts that use an abstraction available in one language that need to be "compiled" to a lower-level implementation in the other language.

So to answer your questions:

I believe a compiler is something very different from a transpiler.

No.

Is Babel a transpiler or a compiler, or perhaps offers both options?

Yes.

Or is the website's title 'Babel - The compiler for writing next generation JavaScript' simply incorrect?

No. That title focuses on next-generation features, i.e. higher-level abstractions that really need to be compiled into a very different output. Even though the output is still ordinary, mostly human-readable, JavaScript.

I am writing documentation relating to Babel, and I want to ensure my description is accurate

In that case, I'd use their own terminology from the official website. If you want to compare the tool to others, choose your own description.

Upvotes: 62

Dennis
Dennis

Reputation: 4017

Transpilers, or source-to-source compilers, are tools that read source code written in one programming language, and produce the equivalent code in another language.

Babel is both a transpiler and compiler as the words can be used interchangeably.

Upvotes: 1

Related Questions