Feeds

Scala daddy wraps his Java baby in Red Hat-ness

Is it Typesafe? Yes it is

  • alert
  • submit to reddit

Intelligent flash storage arrays

Martin Odersky – the man who created Scala, the Java-based programming language that now drives such big name web services as Twitter, Foursquare, and LinkedIn – has launched a company that provides service and support around an extensive open source application stack for the language.

Both the company and the stack are known as Typesafe. Officially unveiled on Thursday, the Typesafe stack includes the most recent releases of the Scala programming language, the open source Akka middleware, and various open source tools designed to facilitate the development of Scala applications. "We want to provide stable versions of the stack, stable supported versions where you can get backports of fixes and improvements", Odersky tells The Register. "It's very much the open source support model you see with Red Hat".

The company will also offer consulting services, but this is not a primary aim.

Odersky, a professor at the École Polytechnique Fédérale de Lausanne in Switzerland, is known not only for creating Scala, but for building javac, the Java compiler included with the Java Developer Kit. First released in 2003, four years after Odersky built javac, Scala runs atop the Java Virtual Machine, and it's meant to be an improved version of the Java language.

"[My javac] work was a worthy undertaking, but it led me to realize how difficult programming was," Odersky says. "I decided to rethink the way we program, but at the same time, I wanted to stay really practical. So I wanted to build something that was completely interoperable with Java, and that's what Scala became."

First and foremost, Scala was built to provide concurrency. "The idea was to address the next big challenge after internet programming, which Java addressed pretty well," he says. "At the time, you could already see that the next big challenge would be concurrency and parallelism." The best way to address concurrency, he says, was through functional programming. For Odersky, mutable variables cause huge problems when you're dealing with concurrent programs.

"Any sort of mutation is really something very dangerous. Once you have mutable states, it's a big headache to cache it, to replicate it – all the sort of things that are your daily bread if you want to have large, horizontally scalable systems. State is really very hard to manage for all those systems."

But Scala would retain Java's object oriented techniques. It's unique in that it blends the object oriented and the functional. For concurrency, it takes a page from Erlang, passing messages between computational entities known as "actors". These actors are the cornerstone of the Akka middleware included with the Typesafe stack.

Because the language runs atop the existing Java Virtual Machine, it provides performance akin to Java and C and, for that matter, Go – the Google designed language that also takes direct aim at concurrency.

The inaugural Typesafe stack includes Scala version 2.9, which offers tools specifically designed for building parallel applications – i.e. concurrent applications that run across multiple processor cores. Version 2.9 marks the debut of a Parallel Collections library that lets you do all transformation and bulk operations in parallel.

The new Typesafe company combines two existing operations: Odesky's own Scala Solutions, and Scalable Solutions, a company run by Jonas Bonér, the Stockholm-based creator of Akka. The third founder is the San Francisco-based Paul Phillips, the largest contributor to the Scala codebase over the last few years.

Typesafe is backed by $3 million in Series A funding led by the Silicon Valley-based venture capital firm Greylock Partners. The company's board of advisors includes Java creator James Gosling and Doug Lea, a professor of computer science at State University of New York at Oswego, who specializes in concurrency.

In addition to the Scala runtime, the core Scala libraries, and version 1.1 of the Akka middleware, the open source Typesafe offers a new Scala Eclipse plugin and a simple build tool for Scala known as SBT. The stack runs on Mac OS X, Linux, and Windows, and it requires the Java runtime version 1.6 or later. ®

Internet Security Threat Report 2014

More from The Register

next story
Be real, Apple: In-app goodie grab games AREN'T FREE – EU
Cupertino stands down after Euro legal threats
Download alert: Nearly ALL top 100 Android, iOS paid apps hacked
Attack of the Clones? Yeah, but much, much scarier – report
You stupid BRICK! PCs running Avast AV can't handle Windows fixes
Fix issued, fingers pointed, forums in flames
Microsoft: Your Linux Docker containers are now OURS to command
New tool lets admins wrangle Linux apps from Windows
Facebook, working on Facebook at Work, works on Facebook. At Work
You don't want your cat or drunk pics at the office
Soz, web devs: Google snatches its Wallet off the table
Killing off web service in 3 months... but app-happy bonkers are fine
First in line to order a Nexus 6? AT&T has a BRICK for you
Black Screen of Death plagues early Google-mobe batch
prev story

Whitepapers

Why cloud backup?
Combining the latest advancements in disk-based backup with secure, integrated, cloud technologies offer organizations fast and assured recovery of their critical enterprise data.
Getting started with customer-focused identity management
Learn why identity is a fundamental requirement to digital growth, and how without it there is no way to identify and engage customers in a meaningful way.
10 threats to successful enterprise endpoint backup
10 threats to a successful backup including issues with BYOD, slow backups and ineffective security.
High Performance for All
While HPC is not new, it has traditionally been seen as a specialist area – is it now geared up to meet more mainstream requirements?
Beginner's guide to SSL certificates
De-mystify the technology involved and give you the information you need to make the best decision when considering your online security options.