Hacker News new | past | comments | ask | show | jobs | submit login
Oracle Wins Revival of Billion-Dollar Case Against Google (bloomberg.com)
778 points by uptown on March 27, 2018 | hide | past | favorite | 615 comments



Appellate courts do not lightly overturn jury verdicts using highly fact-specific reviews of evidence. There is a reason they call a jury a "trier of fact".

There is a reason for this: if it were the rule that an appellate court could easily step in and second-guess how a jury weighs evidence, there would be little room for finality with jury verdicts because lawyers are very skilled (and become very tiresome) endlessly arguing why this or that fact is better than another and why a court should weigh things differently than the way a jury did.

In this case, the Federal Circuit Court did what amounted a wholesale second-guessing of what the jury concluded about the facts here.

I am not saying the issues were not complex and that it had absolutely no basis for coming to different conclusions.

But the zeal with which this particular court upholds IP absolutism is truly a marvel.

This is the court that gave us the frivolous patent bonanza dating back to 1990s by which "everything under the sun" became patentable and many suffered for years from the consequent harm.

So too with the way it is handling copyright law in this Oracle/Google dispute. Yes, by all means, let us protect the hell out of APIs and invite endless future litigation that ensures that easy connectivity in the computer world will no longer depend on engineers but on lawyers. And let us say that "no reasonable jury" could possibly conclude that copying even a tiny amount of code could possibly be "quantitatively insignificant" so as to shield the one doing the copying from claims of copyright infringement, all the better to ensure that future lawyers can conjure up infringement claims from all sorts of seemingly quantitatively trivial copying.

I deliberately exaggerate in how I characterize this decision knowing that it glosses over all sorts of fine points that are the subject of profound argument among lawyers. But I do so to capture the spirit of this decision and what decisions like this mean for computing generally.

Yes, a very broad theory of what is patentable can readily be defended in the name of protecting IP rights and lawyers can come up with endless arguments for why this should be so. So too can lawyers make convincing arguments for very broad theories of copyrightability and very narrow readings of fair use. In both cases, the law protecting IP gets an expansive reading.

Well, speaking as one who has tilled this soil for a long time and who very much supports and sees the need for strong support of IP rights, I can only say that the Federal Circuit Court has proven to be a largely counter-productive force in serving as a specialized court dealing with IP among federal courts. This ruling will do what its prior expansive reading of patent law did: it will set up a legal standard that invites lawyers and litigants to engage in endless second-guessing over copyright and fair use in areas of connectivity and inter-operability in the computing world and this in turn, as a standing invitation to litigate, cannot be good for future development.


"In this case, the Federal Circuit Court did what amounted a wholesale second-guessing of what the jury concluded about the facts here."

It's worse than that. They are supposed to be applying ninth circuit law, and they roundly haven't throughout the entire appeals.

They've made a complete mess of it. First in copyrightability, and now fair use. There are even ninth circuit judges who have spoken out about this.


For someone who is very much on the outside of understanding this situation, if you think you know enough to comment on it overall, would you say that they are mishandling it due to generally misunderstanding the gravity of the verdicts they are handing out or is it more to do with not precisely understanding the technology, what goes into creating such technology, how technology is propagated and improved, and how that diaspora of code and information winds up becoming the open or closed source "fabric" of what we know as computing today?


They just think the ninth circuit is wrong. They are reasonably well informed, they just disagree.

People very often make the mistake of assuming two people with the same data will form the same opinion, and that where people disagree, it must be due to not understanding the data/etc.

In my experience, this is very wrong :)


Thank you. I can totally understand that. I appreciate it.


Of course.

I've met the ex-Chief Judge of the federal circuit, Randall Rader, a number of times (he also taught a class i took in law school at GWU).

He's definitely not stupid, is cognizant of how people view his decisions (he said "they loved me when i wrote nintendo vs. atari and hated me when i wrote other things"), and really did believe he is making things better.

Of course, i strongly disagree, but like i said, it's not like he doesn't understand the issues.


Can the Ninth Circuit itself petition the Supreme Court to intervene and stop the Federal Circuit from making a hash of Ninth Circuit law?


> Can the Ninth Circuit itself petition the Supreme Court to intervene and stop the Federal Circuit from making a hash of Ninth Circuit law?

Technically, this doesn't have any effect on 9th Circuit law because CAFC decisions applying (and I use that term loosely, here) a particular Circuit’s law do not form new binding precedent for courts in that circuit (or even precedent binding on the CAFC itself in future cases applying the same law.)

But, no, the Ninth Circuit can't intervene that way, though tension between Ninth Circuit precedent and a decision, even if non-binding on other courts, in the CAFC presents an issue similar to a conflict between circuits that would ordinarily seem to weigh in favor of the Supreme Court taking the case on appeal, since avoiding effectively having different systems of federsl law applied to different cases is one reason the Supreme Court exercised it's discretion to hear appeals. It seems certain that Google will appeal this.


If anyone wants more background on where the Federal Circuit came from and why it has caused so many problems, check this out: https://arstechnica.com/tech-policy/2012/09/how-a-rogue-appe...


> Appellate courts do not lightly overturn jury verdicts using highly fact-specific reviews of evidence. There is a reason they call a jury a "trier of fact".

Just to get this straight, because I think I roughly know the legal system works in the US, from TV and movies, but then when I apply it to a real world case such as this, it seems too ridiculous for words: by "jury" you're actually referring to a group of about 10-12 randomly selected laymen with no background in law whatsoever, and even specifically selected to also have no background in the subject matter (because knowledge equals prejudice /s), and they get to decide on the outcome of a billion dollar case?


[cynical comment] Do you think the court is trying to guarantee jobs for lawyers?


It's worse than that, they're trying to guarantee profits for companies. Even though this is two titans fighting it out, the only people who benefit from an ultra strict copyright regime will be the people that can afford to fight it out in court. Everyone except people that hold shares in large companies will lose out.


As a shareholder in large companies I’m not sure I even benefit. The legal departments are going to have to have a bigger budget to deal with this, and new IP is going to be costlier to develop / buy / defend.


That lawyers exist is a good thing. It means we have a human, nuanced perspective on the finer points and interpretation of the law, which in Western civilization reigns supreme over all other things.

Lawyers will never become obsolete until we no longer live in a society that obeys the rule of law.


You're going to get downvoted because you're posting this in a forum of largely programmers, many of whom believe that every problem is essentially a programming problem, and that the law could be computer code if only the spec were well-enough defined.

In reality, "defining the spec" is the entire purpose of having a legal system in the first place. A nation is a machine that is evolving its own state. There's no outside "programmer" who can observe and define the entirety of the desired state. (Unless you believe in an active interested conception of God, perhaps.)

The legislators, lawyers, and judges who tell us what the law is, are part of society too--and that's why the law changes over time. It's supposed to change over time. The law constrains human behavior, but it also reflects human behavior, so the state of what's legal right now exists in a weird state of superposition between the two.

But, the fantasy that one is outside of, or separate from, society is a popular one--seen most clearly expressed in the libertarian creed, but popular in Silicon Valley too, at least from a business perspective. What do most tech companies want from the government? To stay the heck out of their business, stay far away, and don't bother me. That includes lawyers.

So you're going to get downvoted here, but I don't think that means you're wrong.


I dislike large numbers of lawyers for the same reason I dislike large amounts of code.

It indicates there is a large amount of incidental complexity.

Clearly, exterminating lawyers or deleting random files is not a workable solution. But we should invest in reducing the system to essential complexity. If we are successful, the symptoms will subside.


I strongly disagree.

In this day and age, there are far too many laws to both understand and be sure you are law abiding. Ignorance of the law is a given. Ignorance not being an excuse for something like murder makes sense because you should just know better, ignorance not being an excuse in possession of the feathers of a protected animal that you found on the ground should be valid even though this presents an insurmountable burden to prosecution: it shouldn't be possible that picking up feathers you find on the ground is a crime, but it is.

The sentence "a lawyer who represents himself has a fool for a client" should be an indictment of the legal system and not a jeer at the self-represented. Justice should be given to those who deserve it, not to those who manufacture it through technicalities. The fact that a lawyer is necessary to achieve justice implies you are not achieving justice but rather merely a bureaucratic victory.

This state just renders law into bureaucracy and divorces it from the concept of justice. The rule of law is only sensible insofar as it can achieve justice, not as its own end divorced of anything humanly meaningful.


> That lawyers exist is a good thing.

The more common term is "necessary evil".


In an ideal world, lawyers would be advocates seeking to provide a nuanced, human perspective.

In the current world, I think it is more common to be seeking loopholes, weaknesses, and exploits instead.


I can see how a person that only knows about law what they read in the headlines could come to that conclusion, but painting lawyers with a broad brush as you have is no more of a generalization than me saying that every Facebook employee is devoid of morals and ethics.


Which lawyers in what context do you see providing that nuanced human perspective?

Corporate law? Their job is keep us from getting sued.

Family law? If you're advocating that human perspective for the opposing party, are you failing your duty to your client?

Prosecutors? Not sure they have that discretion.

General legal services, probate, etc. Doesn't seem that applicable.

Intellectual Property? Human perspective? Unlikely, except maybe the "hard-working inventor" angle.

Defense attorneys? Sure. That could be a good angle - along with any possible opening to exploit.


> Family law? If you're advocating that human perspective for the opposing party, are you failing your duty to your client?

They shouldn't be advocating the opposing party's human perspective in court, but they certainly should be doing it privately to the client. Things will usually work out better for them if they can reach an amicable compromise out of court rather than having to engage in protracted legal battles with their own family.

> Prosecutors? Not sure they have that discretion.

Prosecutors absolutely have that discretion. They don't have to take every case to court and they don't have to seek the harshest allowable punishment for every case they do take to court. They are supposed to be serving the public interest, not seeking to imprison as many people as possible.


Every single point in this post is a broad-brush generalization perpetuated by media stereotypes.


And by limited personal interactions in professional capacities.

I'd love for you to provide countering perspectives from your broader exposure.


Lawyers are essentially social hackers trying to find weaknesses in IP laws and exploiting them for massive profit. It’s essentially court warfare


> Lawyers will never become obsolete until we no longer live in a society that obeys the rule of law.

I think the core problem is that this misinterpets the phrase "rule of law", which Google defines as "the restriction of the arbitrary exercise of power by subordinating it to well-defined and established laws."

If your lawyer's arguments, preparation, and skill matter, or if it matters whether you have a lawyer or not, then you are being subject to "arbitrary interpretation" of the legal landscape, rather than to well-defined and established (and understood) law.

Your /lawyer's/ actions affect the judgment, rather than just your actions.


It may be helpful for readers to look at the actual meat and potatoes of the decision itself. I recommend jumping in at Page 27 of the decision so that they can see how the fair use factors were evaluated in this case: http://www.cafc.uscourts.gov/sites/default/files/opinions-or...

Fair use has four factors, lets see how it shook out:

1) Purpose and Character: Google tried to argue that because android is free that it isn't commercial. Bzzt. Nope. You don't need direct monetization to make something commercial.

Was it transformative? They verbatim copied shit. Google claimed it was transformative because they used it in smartphones, yo. No. You guys who think patents that slap "but use a computer to do it" onto the end of some existing process are bad? Google's trying to say the same thing per computer form factor.

2) Nature of the Copyrighted Work: Dealt with previously - APIs are copyrightable. Lots of people have an issue with this, but the previous opinions on that point are where you should go for material on that point.

3) Amount and Substantiality: Bad faith usage came out around neutral; wasn't a huge amount copied but it was important material, as admitted by Google themselves.

4) Effect on Work's Value: Direct evidence of market harm demonstrated by showing that Amazon leveraged Google's infringement to lower their license payment. Slam dunk.

Overall, I agree with the other posters indicating that once API copyrights were upheld that this was going to be a clear loser for Google. Maybe they'll get cert and have the supreme court take a look at this following the re-trial.


RE> Nature of the Copyrighted Work: Dealt with previously

In my entire career you could not copyright an API. There is good reason for this. If you wanted to do business with certain entities, the implementation had to be multisource. The new implementation had to come from a cleanroom, but in this case it came from open source (which seems equivalent). Therefore you have one judge making one decision that is an anomaly. It seems to me that a single judge should not be making a landmark decision.


There's a lot of similar responses regarding the API copyright issue. APIs have been 'subject to copyright' for 4 years, since the 2014 decision in this case. Lets see some key details:

This is the 2012 ruling: http://www.groklaw.net/pdf3/OraGoogle-1202.pdf

Alsup indicates that SSO isn't dead law, but finds that APIs aren't copyrightable because they are 'the only one way to write" things to get the key functionality. Copyright doesn't cover purely functional elements and since the expression and the function are the same, copyright bows out.

Note: I like Alsup, but this argument is based on obviously factually incorrect premises which are blown up on appeal.

Here's the appeal in 2014: http://www.cafc.uscourts.gov/sites/default/files/opinions-or...

They summarize the facts as follows: " And, the court informed the jury that Google conceded that it copied the declaring code used in the 37 packages verbatim. The court also instructed the jury that Google conceded copying the rangeCheck function and the eight decompiled security files, but that Google maintained that its use of those lines of code was de minimis. See Final Charge to the Jury (Phase One), Oracle Am., Inc. v. Google Inc., 3:10-cv3561 (N.D. Cal. Apr. 30, 2012), ECF No. 1018 at 14 (“With respect to the infringement issues concerning the rangeCheck and other similar files, Google agrees that the accused lines of code and comments came from the copyrighted material but contends that the amounts involved were so negligible as to be de minimis and thus should be excused.”). "

Ie: Google copied and admitted it copied. This isn't a cleanroom implementation.

For more details on why they found copyrightability, see the discussion starting on p.17. There's a lot in there, and having a discussion about it (or at least a proper one) requires people to look at the actual text.

Edit: Made the formatting better.


Why have you chosen to mingle the verbatim copying of function implementations (range check) with the API definition copying? You say google "admitted it" which is a loaded term and you use that to say "This isn't a cleanroom implementation". Google conceded the direct copying of one function implementation and thought it not relevant - IIRC the jury awarded Oracle $1 for that. The rest of the function implementation ARE clean room implementation, and the API definitions are claimed by most of the industry to not be copyrightable.

If this holds up, every programming language that was not originally produced under a suitable open source license will need to be dropped because all software written in those languages will be infringing an API copyright.


I didn't choose to mingle those things. That's just plain what the facts are. I get that you don't like them, but that's tough beans.

The case goes into discussing this directly, indicating that Google's cleanroom efforts give it evidence that it proceeded in good faith, but good faith alone does not intrinsically absolve you of admitted copying (which is an infringement) that's found elsewhere.

Now if you did an ACTUAL cleanroom and didn't take chunks that you thought were trivial, the argument to demonstrate infringement in the first place would need to be localized on the SSO level, where single-option design choices would again be exempted through the doctrine of merger, and we'd have a much different set of considerations.

As per the jury award to Oracle, you'll be happy to know they're going back to first instance to have another trial to determine the quantum. Maybe Oracle will get $1 again despite winning due precisely to the mitigating factors you've raised. Who knows. This case wasn't about that. It was about fair use.


>> I didn't choose to mingle those things. That's just plain what the facts are. I get that you don't like them, but that's tough beans.

There are two things in play here and they are NOT the same. The one the whole world cares about is weather APIs are copyrightable. Weather Google is guilty of copying part of Oracles implementation of the code behind the API is not relevant to API copyrightability. If you can't see the distinction you don't understand software or the real core of the case and should stop trolling. If you do see the distinction, why do you keep insisting on conflating the two?


You've been pointed towards resources that answer all of the issues you've raised, but you haven't read them. Suffice it to say, the decisions do not agree that Google's behavior here is not relevant in determining how to deal with the copyright issue.

Whether or not the supreme court agrees with the IPRs affirmed in this series of cases is another question entirely, but until that comes down, nothing has really changed.

Happy reading.


"I get that you don't like them, but that's tough beans."

It's hard to overstate how difficult it is to separate what you want the law to be from what it is. This is why people do so badly at representing themselves, and even lawyers have this problem.


Yep. There is a ton of layperson misinformation in this thread motivated by how people 'feel' about certain issues without actually reading the decisions or understanding the tests in question. There are laypeople literally getting angry at me that the court didn't say what they think is right.

Oh well. I hope some people found it useful.


Love your work. Makes sense, thanks.


It was quite helpful, thanks for all your comments.


Hi ABCLAW,

I read page 17 and it is clearly written by someone that doesn't understand software. My non-lawyer reading of the justification implies that polymorphism violates copyright law - which is an even deeper issue. This would destroy all modern software development. Yikes! I am now even more confused. Even Oracle would disagree with this point of view.

In your text, you are now making the argument that Google did not have a cleanroom implementation. This is a different discussion that should be on it's own thread.


1) Judges aren't computer scientists, and LOTS of IP cases read very poorly as a result. This is a structural issue with how judges are educated within court rooms regarding the facts surrounding the disputes in question - but let's just accept it as an unfortunate cost to adjudicating the way we do.

Regarding your polymorphism point, you've got the cause and effect swapped. The LACK of polymorphism was the basis for Alsup saying APIs are uncopyrightable. Because there's only one way to do something, the words and the function are linked, and copyright does not protect function, ergo copyright wouldn't protect the word either. This line of reasoning doesn't flow in reverse - Polymorphism doesn't indicate that a work is copyrighted or subject to restrictions upon use, or that various safe harbour provisions/copyright exceptions do not apply.

2) There's no need for a separate discussion. I'm not making the argument; it's literally admitted by Google in the context of this case that they straight up copied chunks of code.


I have just read from page 17 to 33. I expected a load of bullcrap, but ended up with only one nugget, page 31:

> We further find that the district court erred in focusing its merger analysis on the options available to Google at the time of copying. It is well-established that copyrightability and the scope of protectable activity are to be evaluated at the time of creation, not at the time of infringement.

The error is subtle, but crucial: when Sun/Oracle released their API, they gave rise to a new functionality: interoperability with whatever they just created. If someone wants to write a drop-in replacement, they have to read the declarations, copy them all, then write a conforming implementation.

Changing the order of those declarations would still be possible, but one would still have to start from the original files anyway. Assuming those were readable to begin with, any transformation would be a purely legal trick, so they can say "I didn't really copied it".

As far as I can tell the court either ignored or dismissed this interoperability issue. Agreeing with Oracle that Google could have renamed its function names, even though those names are part of the API they were conforming to (the `max` function is obviously part of the standard library), is ignorant at best, dishonest at worst.


Google specifically decided not to use 'interoperability' as a functional objective constraining their code design because there was a wall of evidence against that interpretation. There's a comprehensive write-up elsewhere in this thread about it.


I have read it, and I disagree.

I am not arguing that Google has an interoperability exemption. I am arguing that the API is not (or should not be) copyrightable in the first place, because any attempt at interoperability would instantly void it.

I would also argue that interoperability with the training of masses of developers is a thing. Saying it is not only strengthens the relevant network effects, which is bad for competition. I doubt that last one would hold up in court, but still. See how C++ became popular. Not quite compatible with C, but close enough to spur adoption.

And overall, it is very weird that Google's intent matters here. They should be judged on what they did, and maybe whether they did it on purpose. Why they did it should be no more than extenuating or aggravating circumstances.


>I am arguing that the API is not (or should not be) copyrightable in the first place, because any attempt at interoperability would instantly void it.

The court specifically deals with this assertion and does not come to the conclusion that you do.

>And overall, it is very weird that Google's intent matters here.

No it isn't. This case was about Fair use, and intention matters for some of the test elements. A bunch of people think this case is about API copywritability. They're four years too late to complain.


> The court specifically deals with this assertion and does not come to the conclusion that you do.

I know. I did read their lengthy conclusion.

> A bunch of people think this case is about API copywritability.

Too bad it isn't. That ruling from 4 years ago is insane. And I recall people did complain at the time, did they not?


Hi ABCLAW,

I just reread the document, and I think you are referring to page 36. I think Oracle is trying to get around the Sega vs Nintendo case which does protect the API. I believe the Oracle argument is tenuous since you still need to import the Math class to use it. If you don't import it, they you have to specify the Math class every time you use the method. Even if Oracle is correct, then it would mean the Math class is not in the API, it is an implementation detail. Then we are back to the discussion if an open source implementation is legitimate replacement for clean room implementation. Then this becomes an open source discussion and not an API discussion.

The whole Oracle discussion of API seems circular and might be a red herring. The real discussion is at the very end where Oracle says that Google only implemented a subset of the API and not the full API.


You aren't using the same definition of polymorphism as maire is. In the context of software, polymorphism is the practice of having an interface, one side of which has multiple alternatives which do different things.


> 2) There's no need for a separate discussion. I'm not making the argument; it's literally admitted by Google in the context of this case that they straight up copied chunks of code.

One function, rangechececk.


Which Alsup publicly admonished Oracle's counsel for trying to make a big deal out of it.


> this argument is based on obviously factually incorrect premises

Which premises are you referring to? I am not a lawyer, but I am a programmer, and what you just paraphrased sounded obviously true (at least when "the functionality" means "replacing the old system", a.k.a. interoperability).


And this jury, that made the decision about APIs being copyrightable (in the US), that made this into "a clear loser for Google" in 2014 were also a dozen randomly selected laymen with no background in law nor programming?

Which part of "let's find a small group of the least qualified people to decide on billion dollar cases" ever seemed like a good idea to anyone?

Then there's the judge, who has a background in law but NOT in programming.

Then there's the lawyers, who have a background in both (assuming the expensive lawyers G and O can afford), as well as years and years of practice influencing the decisions of small groups of laymen.


Where is the obvious factual inaccuracy?


How does this not apply, in any way: https://en.wikipedia.org/wiki/Software_copyright#History_of_...

I don't understand how this is never brought up with regard to API copyright. API's are software, software has been deemed copyright-able, thus, API's are copyright-able.

Am I going crazy or missing something?


> I don't understand how this is never brought up with regard to API copyright. API's are software, software has been deemed copyright-able, thus, API's are copyright-able.

This is, essentially, the fallacy of division.

Interfaces to software have been rules non-copyrightable despite being an element of software and thr software itself being copyrightable; this is particularly the case for user interfaces (Lotus v. Borland is the landmark case here.)

There have been many comments from the legal community, including, IIRC, judges that sit on the 9th Circuit, that the Federal Circuit (which heard this case on appeal because of the patent claims in it) has misapplied binding Ninth Circuit precedent (which is supposed to control on coypright issues in this case because this came up from a district court under the 9th Circuit, and copyright law is not one of the areas where the Federal Circuit has exclusive subject matter jurisdiction.)


Many commentators on this thread are desperate to come to the opposite conclusion despite the clear case law on this question.


Because it has some pretty wide ranging effects on our industry, mostly negative (in my opinion). Though wishes and hopes don’t change court decisions, of course.


If API are copyrightable how do clean room implementations work? It seems IBM could sue the clone makers for the BIOS API if that's the case.


That was already decided back in 2014 (Oracle v Google): the jury concluded that Google did infringe Oracle's copyrights, but they deadlocked on Google's fair use defense.

And yeah, I guess that IBM could start suing everybody... this whole situation is so ridiculous.


Does that mean all the cloud providers who are copying S3's API for object storage are violating some copyright?


That is what the new law established by that case seems to suggest...


I'm sure Amazon would love that to be true and force any competitor to beg for licensing.


After all, the sole purpose of such reimplementations would be to take business away from Amazon.


what about things like aftermarket car parts? 3rd party phone cases?


Lego-peg compatible toys made by other producers?

Other forms of structured metadata use cross-party?


Yes, IBM can start suing them with some substantial chance of victory under the new law established by these cases. It's fucked.

Or IBM could realize if they start doing that, it might show the insanity of the current law, and result in the law changing back to what it was and should be, API's not copyrightable.


Google didn't do a clean room implementation, so it's difficult to speculate what this decision might indicate for some other case involving a clean room implementation.

(And yes, I know: The overwhelming majority of the work was a clean room implementation, but not all. In retrospect, this was an unfortunate mistake by Google.)


if that happened today, they might, but until three years ago, APIs were not copyrightable. Or at least not thought to be by most developers.


I think because there are no identifiers. The BIOS API is: fill registers with these values, run this interrupt. That's different from openFileWithName(String fileName).


What? No those are the same thing. Why is an API suddenly not copyrightable if its 0x51234 offset 5 bits, vs human readable text? That is nonsense. Numbers and words should not be treated differently.

What if I named my function 015342342(String 123949)? How does that change anything?


Copyright has a creativity requirement. I can easily see a court ruling that 0x51234 bit 5 is not creative whereas SetBrickMode(true) has a spark of creativity in that it could have been named multiple things.

Without endorsement, there is definitely a line between text in which one can be "creative" and numbers in copyright law as written.

The problem here isn't the line between creative and non-creative, the problem here is the introduction of copyright, a concept created for expressive works, into a field that consists of functional works. It should not be a surprise to anyone, not even lawyers, that this isn't going to "just work". The surprise to me is that it has taken this long for this foundational clash to start emerging at a big scale.


The number sequence to word differentiation you make is specious - you may not consider it creative but there's a creative spark in choice of a number, or choice of a location in memory that leads to choice of a number, etc., as you later intimate that creativity is technically lead.

The choice of call name in an API are arbitrary, the reuse of those names to interface with that API is not a creative copy it's a technical requirement.

If I make a toothed belt to fit a pair of gears, that's not an artistic expression no matter the the tooth pitch is an exact duplicate of that on the gears. If the gear is purple and orange spots, in a distinctive pattern, and I make my belt the same pattern then that's a copyright issue.

If the API calls were like "thisIsTheSummerOfOurDiscoTents(banana)" - such that the names are sufficient to be individual works of art, and weren't following a technical function, then perhaps you have an argument that the API is a work of literature, or otherwise an artistic creation.

It just sounds like a wrong decision was previously made and should now be overturned.


The key word in first bit of my post is "court". I think standing in front of a judge and explaining that your choice of 1,383,929,380 is "creative" is, well, something you're welcome to try.

The real key point is in the second half, though. Arguing over whether or not a particular micro-decision is "creative" is the entirely wrong track to be taking when we're discussing something that is functional, that performs some real task in a way that a movie or song simply does not. Why would we expect standards based on "creativity" to apply to that in any sensible way?


Judges aren't fools (but some can be persuaded to be!).

It's impossible for a collection of letters to be creative but for that collection of letters when represented numerically to be no longer creative. If I make up some BS for how there's a correspondence between these symbols and other symbols (1=alpha, 2=bravo, ...; or 1=sandwich, 2=wellington, ...) - then 1383() is just sandwichBiscuitAppleBiscuit(). Then it's clear the creative aspects of the program, API, or whatever, don't lie in the specific choice of tokens.

Would a judge agree that providing a dictionary/key that says an arbitrary name for each number (easy to do programmatically) makes a program creative that otherwise wouldn't be. It's clearly ridiculous. Not least because it would mean that duplicating a work that was compressed, or represented in binary, would then no longer be a tort, because apparently numerical representation would rule out a work from being creative.


The thing is, any program that calls "SetBrickMode()" HAS to use that name. Nobody has ever claimed programs require the consent of the API creator under copyright law to use the API. EVER prior to this. And then once a bunch of software is created using the API (presumably without need of the copyright holder) someone else doing an alternative implementation for that software to run on has no choice but to use the same naming convention for those programs to run.


You can choose different interrupt numbers as well.


This line of 'concern' has been running through the courts since the mid 80s. This isn't anything new. The cases themselves discuss the jurisprudence on either side, as well as the tests used to determine the magnitude of creativity and similarity as between software products.


openFileWithName is a mnemonic that a software developer uses and which a machine translates into a literal location at compile time.


You actually do a clean room implementation rather than copying chunks of your competitor's work and then pretending it's allowed under fair use?

Seems pretty straightforward.


Google did clean room implementation of almost all functions. They copied 9 lines of implementation code verbatim - out of thousands of lines. It does raise a question in my mind as to how that one function got copies, but it's also possible that it was re-implemented and happened to be done exactly the same without looking at the original - I honestly don't know but Google conceded it was a duplicate either way. 9 Lines. Not a wholesale infringement - seems pretty straightforward.


Those 9 lines got copied because the function was going to get donated to openjdk anyway, so it would be stupid to rewrite a simple 9 line function that it used as that would be pointless duplication after it was merged.

So a Google employee was donating code to Oracle, and they sued them for it. It's absolutely shameful behaviour.


>It does raise a question in my mind as to how that one function got copies, but it's also possible that it was re-implemented and happened to be done exactly the same without looking at the original

They literally admit to having copied it.

All the hypotheticals trying to find the end of cleanroom dev in this case keep missing the point: They didn't do cleanroom dev. They admit to not having done it. Their defenses aren't organized around them doing it. So what's the furor about?


Oracle's counsel was publicly admonished by Alsup for even trying to push that argument.

Alsup: "I have done, and still do, a significant amount of programming in other languages. I've written blocks of code like rangeCheck a hundred times before. I could do it, you could do it. The idea that someone would copy that when they could do it themselves just as fast, it was an accident. There's no way you could say that was speeding them along to the marketplace. You're one of the best lawyers in America, how could you even make that kind of argument?"

David Boies (counsel for Oracle): "I want to come back to rangeCheck."

Alsup: "rangeCheck! All it does is make sure the numbers you're inputting are within a range, and gives them some sort of exceptional treatment. That witness, when he said a high school student could do it—"


> So what's the furor about?

Probably about the absurdity of being hit with potentially astronomical penalties for "copying" 9 lines of trivial code that's barely worth hitting ctrl-c for.

Obviously, common sense is - as always - distant from the pedantic nature of law and laywers, but just about anyone sane is gonna look at this and go "well that's just stupid".


> Probably about the absurdity of being hit with potentially astronomical penalties for "copying" 9 lines of trivial code that's barely worth hitting ctrl-c for.

IIRC, the literal copying of code was something for which the parties stipulated to $0 in damages; the potential liability is about copying the API, not the one trivial 9-line function.


That statement is at odds to APIs being copyrightable. If the API itself can't be used then how exactly is a clean room implementation of that API supposed to avoid the copyright issues of implementing the API?


I'm trying to understand here - is the idea that if they had put a bunch of developers who had never seen the API that they were implementing (normal clean rooms allow documentation, but api documentation is pretty much the signatures and that pretty much is the material we're talking about being copyrighted), provided the clean room engineers only with example code that used the apis and that they had to make work then they would most likely not have a problem, even if the resulting code had blocks that were character-for-character identical (since interfaces likely would come out identical to those they needed to be interoperable with)?

Obviously that sounds pretty crazy, but if it's true, it would at least be an approach that I could understand.


>normal clean rooms allow documentation

Uhhh. No. Just no. I don't think you understand the meaning of "clean room" in this context. In this context, clean room means that the person in the room is untainted by any copyrighted information full stop.


Yes, and the normal way you do this is by having some people (who can be tainted) write a bunch of documentation. Then the documentation gets passed to the people working in the 'clean room' who then implement based on that documentation.

The problem I'm describing is that in this case the kind of thing you'd typically want to write in that documentation is exactly the signatures of methods, which would amount to copying the copyrighted material and would taint the whole clean room. I'm trying to think of a way you could even do clean room engineering if the signatures of methods are copyright information. The reimplement from usage examples is the only thing I can come up with.


Not a lawyer, and I agree with your overall point, but I think usage examples are as tainted as the raw API.If the API is copyrighted with no fair use exemption for interop, why would that protection not extend to the API usage which contain the same information? "void IFoo.bar()" and "myFoo.bar() // returns void" are pretty similar and equally as "infringing" IMO.

These $9 Billion dollars will look great on Oracles bottom line. The mega-billions in possible lost trade and efficiency make me think this ruling gets reversed with a vengeance.


Cool. So if I just make a Mickey Mouse cartoon from scratch I should be good.


Or a film about Snow White, Pinocchio, Rapunzel, Sleeping Beauty etc.


Sure. If you managed to actually do that. Of course courts are free to infer as to the unlikelihood of that.


Disney's whole strategy was taking public domain works like those and making cartoon versions.

There's nothing legally stopping you from doing the same; Disney does not own these stories.


> You guys who think patents that slap "but use a computer to do it" onto the end of some existing process are bad? Google's trying to say the same thing per computer form factor.

This is ridiculous. An argument supporting a fair use defense in a copyright proceeding is a very different thing from a patentability argument. Google is not trying to claim patent rights to its Android API.


Strictly speaking, Java isn't used in Android. There is no JVM in Android, and there never was. It doesn't run Java bytecode. Java ends where dex translates Java bytecode. In recent version of Android, there's another layer where Dalvik bytecode is compiled to the target architecture.

So don't think of Java being in Android. The Android toolchain uses Java, but the Android runtime is not a Java runtime.

For one thing, this makes it different from Amazon using an Oracle Java runtime. But the total set of differences is deep and significant.


It also erodes Google’s claims of fair use. Leveraging the Java language and APIs benefited Google much more than it benefited the Java ecosystem at large. Almost anything that targets Java can now be used on Android, but the reverse is not true. The sharing largely flows one way.

Google had little interest in expanding the reach of the Java platform—they wanted to attract Java developers to their “looks like Java, but isn’t” platform while benefiting from the years of work that went into the JDK.

I don’t necessarily think APIs should be copyrightable, but since they now are as a matter of law, I’m leaning towards Google’s actions constituting infringement.


> The sharing largely flows one way.

While this may hit on our sense of fairness, it has no relation to legal "fair use". My political parody show owes no profits to the subjects of my derision, IoW.


"Benefitting the ecosystem" doesn't bear on fair use at all, but if it did, one could point to Android driving a revival of Java generally, and dragging client-end Java coding out of a coma and into prominence.

The same could have been said of Visual J++ but Sun killed that opportunity before it could really flourish.


IMHO, if API's are copywritable, consider the equivalents :

-) Are Networking protocols copywritable ?

-) Are REST APIs copywritable ?

I am not sure if this is the way open source world should work.


What exactly was 'copied' by Google? Was it actual code directly copied or just the general design / APIs that were mirrored by their Android Java playform?


The court has made the point now that literally just the class and method names are subject to copyright.


Devil’s advocate here... the method signatures, the layout of the classes, what inherits from what, what bits are private vs public, are all pretty non-trivial. Moreover it’s where a lot of the subjective decision making happens, whereas the actual implementations are straightforward once you know what the method signatures should be.

I don’t necessarily agree with the decision but I can see where they’re coming from.


Triviality isn't the determining factor of what's copyrightable.

Edit: And particularly there's tons of case law that this stuff isn't copyrightable, see Sony v. Bleem, where a company literally wrote an emulator of a PS1, and courts said that was fine. Even to straight up sell as a competing product, and for running on competitors machines.

Edit2: And the otherwise shitty DMCA even has explicit exemptions for software interoperability purposes.


In Sony v. Bleem they used blackbox testing and created their own original code from that. If Google had done the sam they would have been fine.


Because of Java's reflection, a black box approach would have given you the same API names that are being discussed here.


Not necessarily. You don't have to "look" at the reflection.


You do to be API compliant.


Bleem did not copy. An emulator is not necessarily a copy.


I think it's important to remember what copyright is meant to protect -- expressions of ideas. You can't copyright the structure of an engine in a car. You can't copyright medicine.

There is a bit of a "intellectual property" slippy slope going on here. Whether or not something is useful or non-trivial is inconsequential.


> You can't copyright the structure of an engine in a car. //

You could design an engine to have an artistic structure. What you couldn't then do is stop anyone copying the functional parts of the engine and leaving out the purely artistic elements.


What's reallly non trivial is getting developers to uptake a new APi they are unfamiliar with.


Isn't Java open source? (Does this not include the APIs that are part of it?)


When it comes to Oracle, it doesn't matter. There's a reason MySQL was forked into MariaDB basically the second Oracle bought it.


Open-source does not mean there are no restrictions. AFAIK, Java's open-source license did include some provisions that Google violated.

PS: I am not a lawyer. Above piece of knowledge is coming just from what I read, perhaps on HN during the previous ruling on the case.


OpenJDK is presently under GPL 2, with the "classpath exception" at the end: http://hg.openjdk.java.net/jdk9/jdk9/file/a08cbfc0e4ec/LICEN...

At the time, though, I don't believe it was open source and OpenJDK originated as a cleanroom rewrite of it, and has since been integrated.


I thought Google used the implementations!


I thought one of the main issues was that there was only one natural implementation of many API functions. Like when you assign students a coding question, you will see many answers come back identical even though no one cheated.


Even then, there were only a couple trivial places that saw literal copying. The code that checks for array out of bounds was the main one.


They mostly used Apache Harmony's implementations.


The Java API definition.


[flagged]


If they stole Java then you have stolen all the words in your comment.


From the ruling:

> The Java API is a collection of “pre-written Java source code programs for common and more advanced computer functions.”

I'm not too familiar with Java, but I believe they are mistaking APIs for libraries there. Did Google infringe on the libraries or the actual API?

Like did Google actually infringe on what Oracle calls the "Java API" (but is actually a library), and are we all talking past each other when discussing "API copyrightability" when Google may have actually been found of infringing a library?

I think the CAFC may be just as confused about which one is which and on which it's ruling.

Additionally, how would this relate to the Java programming language being "free" and why would Google infringe on anything if it was free?

I don't know the actual details of Sun's licensing, though, but even from what Oracle is claiming now, it seems that Oracle's case is quite weak, and I don't see how its license specifically banned Google from doing whatever they think they did.

Finally, the CAFC's pro-patent rulings are almost always overturned by the Supreme Court, and if I believe they wouldn't even have gotten this case if Oracle hadn't also accused Oracle initially of patent infringement. If Oracle had only accused Google of copyright infringement, I think some other court would have gotten the case, maybe a court with less of a bad record in understanding IP law (going by Supreme Court's rulings at least). It's just a shame that Obama's pro-IP laws lawyers got in the way and convinced the Supreme Court to reject the case.


Did Google infringe on the libraries or the actual API?

Supposedly, both. They made an API with the same structure, names, etc. They also copied a nine-line function called rangeCheck.

Additionally, how would this relate to the Java programming language being "free" and why would Google infringe on anything if it was free?

"Free" is not a legal license. Google would have to start from the OpenJDK implementation, and be subject to its license, which they didn't.


> if Oracle hadn't also accused Oracle initially of patent infringement.

Was this a mistake or did Oracle actually accuse themselves of infringing their own patents?


That sounds like something Oracle might actually do.


The case had some patent infringement accusations, some patents were thrown before the lawsuit started and others were considered not infringed


> Dealt with previously - APIs are copyrightable

IANAL, but doesn't this contradict case law elsewhere?


No


>> Dealt with previously - APIs are copyrightable.

Bzzt. You really need to make a citation for that statement. Without it there is no point in considering your other 3. The case law around that issue is exactly Oracle vs Google.


But Oracle vs. Google is the citation. Google previously won based on Fair Use. By definition, that court considered APIs to be copyrightable. If they weren't, the case would have been adjudicated on those grounds instead of the provisions of copyright law that govern fair use.


The district court found APIs to not be copyrightable. The Federal Circuit disagreed, and ordered the district court to hold a trial under the assumption that APIs are copyrightable—that's when Google's fair use defense became necessary.

That Federal Circuit decision has not been reviewed by the Supreme Court, does not establish binding precedent outside the context of this case, and is widely seen by outsiders as being in error for not matching what the Ninth Circuit would have ruled.

It is incorrect to make any categorical statement that APIs are copyrightable. That question is still pending. All that's been settled is that this one case is being conducted under the assumption that APIs are copyrightable, until such time as the Supreme Court decides to review this issue.


> That Federal Circuit decision has not been reviewed by the Supreme Court, does not establish binding precedent outside the context of this case,

The Supreme Court need not weigh in in order to make the law what it is.


Sure. Honest question: is it law now? As of March 2018? What need to happen for API copyright to become law, if the answer to that is “not yet”?


The CAFC can't set precedent on this matter.


The law is what it is by definition, but when what the law is is in dispute, the Supreme Court is what resolves it.


That creates a circular argument.


Bzzt. They're cited. By me. In this thread.

The 2018 decision is not the same as the 2014 decision or the 2012 decision.


Bing Bing Bing Bing. Everyone, read this last sentence. It is correct.


So then theoretically, Intel could sue AMD for supporting their x86 ISA?

1) AMD chips aren't free and the usage is totally for a commercial purpose.

2) ISAs are an API.

3) While the implementation is probably clean-room, it's still a total copy of the ISA structure and function call/return value.

4) Intel has been directly harmed by AMD competition, which results in them needing to be price competitive in certain markets.


AMD has a long-standing cross licensing agreement with Intel regarding x86


Isn't that for patent infringement? EDIT: nope it explicitly covers the ISA, too


Don’t they cross license because AMD does need permission to reproduce an ISA?


isn't that just for patent infringement? EDIT: nope it explicitly covers the ISA, too


I think the part that gets lost in all of this is that Sun offered to license Java to Google previously for $100M. [1] Google turned that down and bypassed Sun because they didn't want to pay (or license). At the time, Sun was happy to see Java being used by Google, even without the license. Still, Google knew exactly what they were doing. [2] My point is, they did this to themselves and they knew what they were possibly getting into.

[1] https://www.computerworld.com/article/2509401/technology-law...

[2] https://www.cnet.com/news/why-oracle-not-sun-sued-google-ove...

EDIT: Added the second reference and cleaned up thoughts. Included note regarded license as well as pay.


But the thing is Google didn't use the Oracle Java engine. They implemented their own runtime environment that's mostly API compatible with Java (and getting further from that as the years go on).

This gets into really critical concerns around APIs. If commercial product A sucks and I'm in a shop where we made our own drop in replacement that implement's A's APIs .. then we open source that drop-in replacement and put it on Github so anyone can use it, are we no violating their copyright just by implementing their API?

This can set dangerous prescient when it comes to interoperability and reverse engineering.


And yet Oracle ships an S3 compatibility API: https://docs.us-phoenix-1.oraclecloud.com/Content/Object/Tas...


Hell, Oracle got started by cloning the SQL API.


Which they payed for, unlike Google has done with Java.

SQL standard and the respective certifications have to be payed for.


The ANSI/ISO standards came out nearly a decade after Oracle's DB was released.

Before that, Oracle ripped off Chamberlin and Boyce's work. Which they should be able to do, because APIs shouldn't be copyright-able.


And how do you think standards get written, out of thin air?

At least Oracle payed something back, unlike Google, ripped off Sun and then stepped on it on their dying breath.

If it wasn't for Oracle we would be stuck porting Java 6 to other languages.


Most of the folklore seems to point to the ANSI/ISO work being done by IBM.


Does anyone actually use the Oracle Cloud? From my attempts, it's only full of misery and broken tech.


Oracle increasingly resembles the old CA. A huge licensing portfolio company with some tech/r&d on the side where good software goes to die.


So you're saying it's an Oracle product?


It's called brand recognition.


It's growing rapidly in Enterprise IT on all all three fronts IAAS, PAAS, SAAS.


Do you know something nobody else does? Because the news seems to indicate that its growth has been slowing for a year now, which is not good news in a rapidly growing market. https://finance.yahoo.com/news/oracle-apos-cloud-growth-disa...


> reverse engineering

That is certainly an issue if you reverse engineer anything. Google went out of their way to NOT reverse engineer it.

The issue is can a public API be copyrighted. That is the scary issue.


I don't get why it's a scary issue or even controversial why an API would be subject copyright. An API, in my mind, is similar to design drawings or blueprints. Independently figuring out how to implement those drawings doesn't change the fact that you copied the design.


If you apply this view to all APIs, the computer revolution would never have happened. The PC was a clone of IBMs API. They fought this battle and lost and now we can argue about it on little handheld clones all day long.


In fact, IBM was so sure that the BIOS API could not be copyrighted they basically made their source public (in the manuals but NOT open source) so anyone reading the manuals to understand the BIOS was tainted and couldn't write a competitor. Compaq did a clean room setup to get around this.


>IBM was so sure that the BIOS API could not be copyrighted they basically made their source public

That is not how copyright works. You almost got it right with your comment "anyone reading the manuals to understand the BIOS was tainted and couldn't write a competitor."

Copyright protects against copying. It does not protect against independent development. Hence the clean room set up.


If the BIOS API was copyrightable, they would have had to do nothing and simply declare that they owned the copyright to the API and thus no clones. Since they couldn't do that, they had to go to the extra step.


Replying to your comment below. I am not missing your point. I am merely pointing out that your point is incorrect as a matter of law. Copyright does not cover re-implementation. Copyright only covers copying. Your statement that IBM could sue company using a clean-room developed re-implementation of IMB's BIOS if IBM owned a copyright to their BIOS is incorrect as a matter of law.


> Your statement that IBM could sue company using a clean-room developed re-implementation of IMB's BIOS if IBM owned a copyright to their BIOS is incorrect as a matter of law.

To the extent that it's relevant here, that appears to be untrue. This hinges on the fact that with an API, you have to match it exactly, and there's no reasonable way to argue that someone could sit down and do a clean room implementation of the Java APIs that perfectly matched all 3000 classes and all the public interfaces of all those classes.

You can do a clean room implementation of the Java Platform, but you can't do a clean room design of the Java APIs. The whole point you're trying to solve is to make something that's compatible with Java, and that requires knowing the Java APIs, i.e., it's not a clean room. If we extrapolate that back to IBM and clones, as long as the clone makers must come up with the same external API as the IBM BIOS, then this court would say that IBM absolutely could use copyright law to prohibit clones, because the clones would have to have copied the APIs -- not the code, but the names and types used in the APIs themselves, and IBM holds copyright to those names.


> Copyright does not cover re-implementation. Copyright only covers copying.

Coypright covers derivative works of copyright-protected works, as well as literal copies. If APIs are copyrightable, there is a very good case to be made that a reimplementation of an API implementation (not an API that serves a similar function, but an actual reimplementation) is a derivative work of the API itself.


An interesting argument. However, the Oracle Google case is not about derivative works. Google admitted to copying.


> However, the Oracle Google case is not about derivative works.

The Copyright Act, however, is; if APIs are protected by copyright, than making a derivative work of an API is an exclusive right of the copyright owner.

Which is a key reason why there is widespread concern about the CAFCs ruling on API copyright. (OTOH, Google losing on fair use at the CAFC makes it more likely that the API copyright issue gets to the Supreme Court in this case rather than a later one, so it might be a good thing for resolving that concern.)


Clean room reimplimentation is not considered a derivative work. Derivative works requires actually copying (and then derivatizing).


> Derivative works requires actually copying

No literal copying of text is required for something to be a derivative work. Transforming a work implementing an API into documentation describing the API would produce a derivative work of that API, if the API is protected by copyright. Transforming that documentation of the API into another implementation of that API would also produce another derived work of the API.


Clean-room reverse engineering produces an implementation that is not a derivative of the original implementation. But if the API itself is copyrightable as a separate work from the implementation, then you have to consider whether the API of the reverse engineered implementation is a derivative of the API of the original implementation. The answer to this question is rather obviously yes, since the reverse engineering process is all about separating the API from the implementation and copying only the former. Clean-room reverse engineering is only useful in a world where APIs aren't copyrightable.


> Clean-room reverse engineering is only useful in a world where APIs aren't copyrightable.

I disagree. However, I am not aware of any caselaw on this point. It is an interesting logical twist you have added, but I fail to see how it must be that way in view of the fact that copyright explicitly allows clean-room type reverse engineering.


> in view of the fact that copyright explicitly allows clean-room type reverse engineering.

The legal status of reverse engineering is not at all clear-cut. There are many nuances depending on the circumstances, and much of it is determined by case law rather than statute. There's no clear basis for you to make claims about how this new class of copyright (on APIs) will interact with reverse engineering. However, it is much simpler to state that if APIs are a work subject to copyright, then it must be possible to make derivative works of APIs that are also subject to copyright absent any explicit exception or fair use right.


Well of course it is possible to make derivatives of APIs that are also subject to copyright. My point is that it is also possible to make a clean room reimplimentation that is not a derivative work, which is much more valuable. Just don't copy is the lesson here.


> My point is that it is also possible to make a clean room reimplimentation that is not a derivative work,

You have not at all established this point. What makes you think that the API of a reverse engineered implementation is not tainted by the copyright of the original API? It's clear that clean room reverse engineering produces an independent implementation, but it also seems clear that such a technique does not prevent the structure, sequence and organization of the original API from strongly influencing the structure, sequence and organization of the reimplementation's API.


That is simply incorrect. Copyright covers copying. It does not cover independent re-implementation. That is the point of clean-room re-implementation. It is not copying because--> clean room.

Silly Example: you design a phone book containing all the names and phone numbers of everyone in the city. To the extent that any subjective decisions were made in the design, it is a copyrighted work. I design a phone book. If I copy yours, it is a violation of your copyright. If I collate the underlying information and then make my own phone book it is not copying, even if it looks exactly the same.


No, you are not getting the point of the whole "copyright the API" thing this discussion is talking about. If I can copyright the API then it doesn't matter if you clean room or not since the API is copyright and I can sue the heck out of you no matter how you did your work. That is my point that you are missing. IBM didn't believe they could copyright the API so they took some additional measures. If they thought the API was copyrightable then Compaq would have gotten sued out of existence. This is what makes Oracle's assertion so scary for the computer industry.


Actually, you're not getting it. Copyright means I can't copy your work. If I arrive independently at the same thing, then I didn't copy your work and therefore didn't violate your copyright.

If I take your picture of a building and copy that's a copyright violation.

If I take a picture of a building from the exact same angle you did, that's not a copyright violation.


That's true, but if you type and distribute a book that happens to match the latest Harry Potter, nobody - including the courts - will believe you independently came up with that exact sequence of words.

Similarly, if you copy the definitions of all functions/methods/classes/etc from one API, nobody will believe you independently came up with it.


Even if the methods and functions are so basic as to not have variations?


It's hard to tell about APIs, since there's no caselaw, but the rule for texts is that the smaller they are, the more original they have to be to qualify for copyright protection - so conversely, the sheer length of a work makes it more likely to be protected even if it's not that original.

So "add(a, b) returning the sum of the two" is probably not copyrightable by itself, but a whole namespace full of functions might be.


No. But the court explicitly looked at that and said that there was enough creativity in the choice of what names to give methods and how to group methods that the Java API qualifies as a creative work (and I don't think anyone would really dispute that).


> If I arrive independently at the same thing, then I didn't copy your work and therefore didn't violate your copyright.

That's not how it works for copyright. Beyond that, how do you independently arrive at an API that you are trying to have an exact copy of? Photography is not programming. I cannot run a bunch of words through a program until it prints out some book I want and then say I arrived at it independently. You honestly need to read the copyright laws as you are missing some information.

[edit: the original premise of all this thread is IBM didn't try to copyright the BIOS API]


I suppose you could argue that black box reproduction is simply an elaborate form of copying. That's not relevant to this case because Google did simply just copy it.


Then why did you bring it up? My original post was about a situation where the creator of an API didn't believe it to be copyrightable and then made an attempt at protecting it a different way. Oracle believes they can copyright an API and almost everything in the industry was built with the belief that you cannot copyright an API.


>My original post was about a situation where the creator of an API didn't believe it to be copyrightable

Your original post was about IBM not being able to copyright the PC Bios. Which is simply not true in any way shape or form. https://www.allaboutcircuits.com/news/how-compaqs-clone-comp...

Relevant portion "But one problem remained with their IBM-compatible machine. How would they recreate the IBM BIOS without breaching the copyright? Why did they need a compatible BIOS (basic input output system)? . . . Some companies, such as Eagle, copied the BIOS either by reading the IBM manual to understand which interrupt codes did what or by simply copying the hard-coded ROM chip that holds the BIOS. This breached the copyright that IBM had over the BIOS and so did not take IBM long to prevent such companies from selling more of those machines. However, there is a way to bypass these types of copyrights with the use of a “clean room”."


You don't seem to understand what an API is.

The API of a BIOS is not the whole thing! It just specifies the interface by which the BIOS can be called by the OS.

For a crude analogy, consider the interface specification that most modern cars adhere to: there will be a steering wheel with a certain shape, size, and position relative to the driver's seat; there will be two or three pedals, with the accelerator on the right, the brake pedal to its left, and the clutch pedal, if present, to the left of the brake; etc. etc. None of this tells you whether the car runs on gasoline, diesel, CNG, or electricity, or whether the motor is in the back or the front, how many cylinders it has, etc. — all these are implementation details that do not usually affect the interface much.

The implementation of the BIOS — the code that actually performs its various functions — is clearly copyrightable, and always has been. But the API is just the specification of what those functions are and how they can be invoked. Imagine if one car manufacturer had been able to copyright the steering wheel and pedal arrangement that we're all familiar with!


Your original post was about IBM not being able to copyright the PC Bios. Which is simply not true in any way shape or form.

No, no, no, that is not what I said. I was talking about the API of the BIOS. The BIOS source code is, of course, copyrightable. That is why IBM was able to make it very hard for people to copy it until folks did a proper clean room. Why would I go into detail about the counter measure if it was not copyrightable? That makes no sense.


Interesting edit to your original post. So their countermeasure was to try to taint everyone in the whole universe so a clean room reimplimentation would not be possible? Wow. Interesting interpretation.


That is not an interpretation, that was an actual strategy. They put enough information and source code into the documents that described its function to taint anyone who read the documentation. There are multiple sources (and I do believe some TV) on IBM's strategy. Compaq's Garry Stimac realized the problem when he read the manuals. A clean room strategy was setup.


You said: >My original post was about a situation where the creator of an API didn't believe it to be copyrightable and then made an attempt at protecting it a different way.

What "different way" are we talking about here? IBM asserted their copyright quite forcefully against Eagle and shut them down.


You really need to read ScottBurson's commen https://news.ycombinator.com/item?id=16693994 because you don't seem to understand the difference between an API and source code.

Eagle directly copied the source code of the BIOS, they were not sued for copying the API.


There's a fundamental difference between:

Blackbox testing -> API Specification -> Implementation

and

Copy API Specification -> Implementaton

In the first case, you will come up with something similar but ultimately original. In the second case you are blatantly copying someone else's work.


...I don't really see what the difference is. In both cases Google would end up with exactly the same API specification. There's no room for them to come up with an "original" API, because if the API they end up with is not an _exact copy_ of Oracle's, then software written for Oracle's Java implementation would not be compatible with Google's Java implementation (and vice-versa).


So? The proper response would have been for Google to either pay the license or develop their own write once use anywhere software. Instead, the took the shortcut of copying someone's hard work.


By that logic WINE shouldn't be allowed to exist either, since it copies Windows' API.

Copying APIs is strictly necessary for interoperability. Allowing APIs to be copyrightable encourages monopolies by legally prohibiting newcomers' software from being compatible with their competition.

It'd be like if Microsoft were allowed to sue Google Docs and Libreoffice for making their software able to open Word documents. (Except in this case the "documents" are source code.)


I'm not sure how WINE works. But I just don't see that being the case. All WINE has to do is capture the API calls and transform them into a different WINE API call that ends up performing the same function and then proceed with zero copyright issues.


> All WINE has to do is capture the API calls and transform them into a different WINE API call that ends up performing the same function

How can it "capture" the calls without knowing what it's capturing? It has to know that there's a windows API function called "CreateWindowEx" that takes particular parameters, otherwise how could it possibly "translate" it? And the fact that CreateWindowEx takes particular parameters is precisely the API.

Of course the implementation of that API will be different in WINE, just as Google's implementations of the Java API are different from Sun's (aside from the 9-line rangeCheck which is a separate issue). In fact it would be fair to describe what Android does as "capture the API calls and transform them into a different Dalvik API call that ends up performing the same function".


> All WINE has to do is capture the [Windows] API calls

So... you're saying it needs to implement the Windows API? If APIs are copyrightable, then that's a violation of Microsoft's copyright. You've included a copy of Windows' API in WINE.


Interoperability trumps copyright IMHO.


Unfortunately courts don't pay attention to your opinion. They only pay attention to grumpy old codgers who don't really understand technology or innovation. They only understand precendents or long ago useless decisions of previous courts and the pragmatism of someone raised on thoughts on computers and ideas of fairness from the 1950s.


It is effectively impossible to take something as complex as the Java API, do black box testing, and come up with an exact copy. Google's API being slightly different is ultimately the point. The process yields a new original work even if it ends up being 99% the same as Oracle's API.


The 1% that's different being... what? Bugs? Like I said, any differences in Google's version of the API would, by definition, be interoperability problems that need to be corrected.

To make that more concrete: if Oracle's string concatenation function is called `String.concat` and Google's is called `String.append`, then code which calls `String.concat` isn't going to work with Google's implementation, and code which calls `String.append` isn't going to work with Oracle's implementation. It doesn't matter if the APIs are "similar" or not, they have to be _identical_ in order for code written for one system to be interoperable with the other.


The 1% will be things like String.methodNoOneUses or ObscureClass. Even if they aren't identical they will be close enough for 99.999% of the programs people write.


So bugs nobody files then? Why do you think this is a useful distinction. Either APIs aren't copyrightable or we should pass a law that says they aren't immediately.


[flagged]


APIs are copyrightable under a CAFC decision notionally applying 9th Circuit law in this case which the Supreme Court declined to review because, pending the resolution of other issues, they viewed it as not ripe for review. Since this is not within the CAFCs special subject-matter domain (patents or any of the other areas which bring a case within it's jurisdiction; this case is at CAFC because to once had patent claims even though they are no longer live), this ruling doesn't seem to be binding precedent on any lower court. So, it's “law” in only a very weak and tenuous sense.


Well, I would love to hear about a circuit court case that says otherwise. Seriously, I have no idea, but I do not believe such exists.


Basically it's not the law yet and may never be the law.


Uhh. No. At least under any interpretation I know about what the law "is."


It's neither express in the statute nor is it in case law binding on any court, because while CAFC decisions are nationally binding, that is only on the subject matter uniquely assigned to the CAFC, but that doesn't include copyright. Those are claims the CAFC decided under 9th Circuit case law in a case that is in its jurisdiction because it once had patent claims, even though those claims aren't active. Had the actual 9th Circuit ruled this way, it would be 9th Circuit case law, but the CAFC applying (notionally) 9th Circuit case law doesn't create new 9th Circuit case law. It doesn't even create precedent binding on future CAFC panels, even if those panels are themselves applying 9th Circuit case law. It is at most persuasive authority, rather than binding authority, in any future case, so it is only “law” in the sense that, e.g., scholarly treatises on the law are “law”.

So, barring this case being both heard and affirmed by the Supreme Court, this interpretation of copyright law, while potentially decisive in the outcome of the present case, isn't, substantially, law, so much as an idea of what the law might be.


Bugs are a red-herring to the discussion. Bugs doesn't get you out of copying. The question is: did you copy or not? Google argued "we certainly did copy but APIs can't be copyrighted." Which was not the law at the time they did the copying and is not the law now .


Except it is the law now and then that APIs aren't copyrightable according to the court that's generally supposed to handle such things, in this instance The US Court of Appeals for the Ninth Circuit. They've ruled plenty of times on the matter, and have developed decades of case law stating that implementing APIs is totally kosher. Sony v. Bleem is great example. There the appeals court ruled that not only could Bleem ship a PS1 emulator with reverse engineered APIs of the kernel (explicitly as a commercial venture even!), but they could port it to a competitor's game console (the Dreamcast), and use Sony's IP in screenshots.

But, because Oracle v. Google case had an ancillary patent question in an earlier appeal, the appeals are instead going to the Court of Appeals for the Federal Circuit. This court is really only supposed to answer patent questions. The CAFC can't set precedent in these matters, and overwhelmingly defers to the district courts' precedent. Bot for some reason they have chose to ignore all of that this time and make their own, fresh (and super weak) precedent that only applies to copyright cases with patent questions.


I bet if one looks hard enough he would find links between these judges and moneyed interests tracing back to Oracle.


Eh, I wouldn't go that far. CAFC judges just tend to be appointed (at least a little) for how much of a hard on they have intellectual property rights in general. The whole circuit was setup pretty much only to do patent appeals for the most part. The judges probably just think of themselves as 'principled'. And they are technically allowed to do this, despite it being kind of a dick move.


>APIs aren't copyrightable according to the court that's generally supposed to handle such things, in this instance The US Court of Appeals for the Ninth Circuit

That is just not true. According to the well-pleaded complaint rule, the Federal Circuit had jurisdiction.


> According to the well-pleaded complaint rule, the Federal Circuit had jurisdiction.

The Federal Circuit has the right to hear and decide this particular case, but they do not have the right to establish binding precedent on lower courts or other appeals courts in matters of copyright law. This has been explained to you repeatedly.


>not only could Bleem ship a PS1 emulator with reverse engineered APIs of the kernel

Not all types of reverse engineering is considered copying. See IBM PC BIOS cases.


There weren't "IBM PC cases". All of that work was based on Apple v. Franklin, a 9th circuit case that held that APIs aren't protected by copyright.


How do you propose they do this black box testing?


Write code, run it through the compiler and create specifications based on what you observe.


And once again, you'd end up in exactly this legal situation since the names are visible via reflection, but somehow aren't functional as viewed by the court.

That's one of the most important issues with this ruling; it effectively bans even black box reimplementations.


It is not copyrights problem that obeying the law might be difficult.


People who reversed engineered the IBM BIOS had the API specification -- actually they had the entire source code. They didn't just fire random interrupts at the BIOS and see what it did. But what they did do was take that specification and describe it the detail necessary for completely fresh implementation.


Not true at all. It was a clean-room reverse engineering job. Yes, they could have looked at the API, but they did not. More specifically, they erected an information wall between those who had the API specification and those who did not, and used the results from those who did not.


One team looked at the API and source code and everything and used that to develop the specification for the "clean" team to implement. That's the point. Collectively they didn't start with nothing.


To me it's more like copyrighting the standard height of a door.


It's more analogous to -- very analogous to -- the "clean room" BIOS clones that enabled the PC Clone industry to take off (and made IBM-compatible PCs actually affordable; before the clones took off, IBM's prices made Apple seem like a bargain).


Atari and Amiga prices were quite competitive, offering much more than those early expensive PCs.


Except Google did not do a clean room clone. They simply copied, thus violating the whole point of copyright. If they had developed their own API that simply used different names but was functionally identical, they would not have violated copyright. Copyright protects against copying. They didn't do that because they wanted to take advantage of the huge existing JAVA developer base who would easily be able to use the copied APIs to develop for Android. I.e., Google chose to copy and thus are liable for that choice.


AS has been covered elsewhere, an API is a functional description and not copyrightable, irrespective of what a specific court says. This specific court has had its rulings slapped about so much by the next higher court, it is a wonder that they haven't just packed up and gone home.

That is why telephone books and others things are not copyrightable. They are lists of facts. API's are lists of facts, a functional specification for use.

There are consequences if this stands and it will not be to our benefit as programmers, developers, designers, etc. Nor will it be to the benefit of society as a whole.


Telephone books are copyrightable. This is black letter law. As said by the Supreme Court in Feist, "Notwithstanding a valid copyright, a subsequent compiler remains free to use the facts contained in another's publication to aid in preparing a competing work, so long as the competing work does not feature the same selection and arrangement,"

In other words, if it does feature the same selection and arrangement, it is a violation of copyright.

Your statement that APIs are not copyrightable is not true as well.


Where can I go copyright my phone number? I want to make those marketers pay a royalty for even storing my number.


An api with different names isn’t functionally identical, at least not without some sort of very weird indirection.


It depends on your meaning of functionally identical. In the hypothetical non-copied Android ecosystem, it could be functionally identical. In terms of interoperating with Java, no. But I fail to see the relevance of the latter point with respect to copyright. Copyright says: don't copy. If that unfortunately makes it difficult to leverage the existing Java developer base for your multi-corps next megaproject, too bad. Develop your own ecosystem.


The Java API is hundreds of classes and thousands of methods. It is far beyond something as simple as the height of a door.


I don't see how the size of the spec has anything to do with it. It could be the standard height of doors or the standard interface/protocol between every sensor and smart component in a smart home.

What if I create my own smart home server that can be a drop in replacement for some commercial product using just what I've gather from their public API? Is that infringement, when the underlying implementation is entirely my own?


You can't copyright trivial work so the size of the spec matters.

It depends on how you create your server. If you go to their website, look at their API, and start typing identical code then that's not ok. It's pretty clearly copying. If you do black box testing and then write your own API that's fine. It's clearly not copying but a new original work.


And what criteria should be used to tell when an API is complex enough to be copyright-able?


Generally, anything can be copyrighted as long as it's sufficiently original. The phrase “I have abandoned my search for truth and am now looking for a good fantasy”, for example, is under copyright by Ashleigh Brilliant, who own a case against a t-shirt manufacturer using it.


It's scary because let's say you are competing with someone, so you decide to copy their API to make it easy for people to migrate over to your system rather than use their system. Now, instead of just doing that, you have to get a license to use the API. Otherwise, you are a copyright infringer.

Take this as an example: https://docs.us-phoenix-1.oraclecloud.com/Content/Object/Tas...

Here is an example of a potential copyright infringer copying the API for another competing service. I'd hope they acquired a license for it, otherwise.


How is an API different than any other product specification? Why can't e.g. Panasonic sue other manufacturers for making an 18650 form factor battery cell? Why can't Ford license the form factor that every car uses for a gas nozzle? There's fundamentally not a way to create your own compatible implementation without using the same API.


Panasonic and Ford own copyrights on their CAD drawings for those items. So I can't just CTRL C and CTRL V and send them off to a manufacturer to get my own stuff made. I can, however, measure those things and create my own drawings without violating copyright because I am not reproducing the work.


So google could've looked at all existing Java source code, and infer the api? But the resulting output is indistinguishable from just copying.


Reflection means that you can, through automation, observe the complete set of public classes, methods, and fields in the java api without ever looking at docs. You can put together a script to do this in 15 minutes.


Design drawings is an implementation, not an API. Copying a drawing is like copy-pasting code from someone else. Something akin to API in art would be style. If you allow style to be copyrightable, it would mean any apps following the Material Design style, for example, would infringe Google's copyright.


The API is less like the blueprints and more like the building code. This is perhaps a bad example as many building codes are copyrighted, but a lot of people find this as absurd as copywriting an API.


Building codes being copyrighted is fine. But if I want to make my own building code, but have all existing builders be able to easily transition, then I must necessirily be making a copy.


Can you copyright the architecture of a building? Like can you copyright the opera house so that no one else can build something similar or a copy?


Yes, but you can't copyright the technical structure - so the acoustically designed internal structure can be copied unless it's protected by IPR other than copyright (patent, industrial design rights, whatever). The external appearance, AIUI, is chosen primarily on artistic merit and so would be under copyright. Facets that are technical, how panels are adhered, how drainage works, they could be copied.

Using this as an analogy for the API would mean anything that was part of the technical implementation could be copied but inconsequential or artistic parts couldn't. This has been interpreted to mean that the actual code is "creative", so you'd have the framework of the code but not the non-essential parts that could be different and still allow the API to work.


> The issue is can a public API be copyrighted. That is the scary issue.

In Roman Law there is the principle "In dubio pro reo" (https://en.wikipedia.org/wiki/In_dubio_pro_reo), which means that if there are doubts whether the culprit is guilty or not, he/she may not be convicted.


I feel like this probably is intended to apply in criminal cases and not civil. (And a copyright case like this would certainly be civil, and not criminal)

In the US, it at least seems that something similar does, in so far as we require a unanimous vote by the jury to convict someone in a criminal trial, but a simple majority for a civil.



> They implemented their own runtime environment that's mostly API compatible with Java (and getting further from that as the years go on).

That's not quite right - Google adopted Apache Harmony[1] (an open source project, and if you want to attribute an organisation responsible for Harmony's success - such as it was - it would be IBM). Apache Harmony would have been 100% API compatible with Java had Sun (and later Oracle) not refused to provide the Technology Compatibility Kit (TCK).

The Android runtimes (Dalvik, then ART) never had compatibility with Java bytecode, instead, Android build-tools use(d) Java bytecode as an intermediate pipeline step; the ultimate executable had 0% compatibility with the Java runtime.


I don't think that's quite right, either (though I could be wrong). IIRC, Android first was done based on Sun/Oracle Java. Then (and maybe even after the lawsuit started?), Google shifted to Harmony.


Are you perhaps referring to Android's very recent switch to GPL-licensed OpenJDK[1] from Harmony after the lawsuit? There was no GPL licensed (and certified) version of Java when the Android project kicked off - OpenJDK came into existance later. Also - Apache Harmony predated OpenJDK by a few years.

1. https://arstechnica.com/tech-policy/2016/01/android-n-switch...


Yes, that's what I meant.


GNU/Linux is a partial (but incomplete, since no Linux distro is unix(tm) certified) a reimplementation of proprietary Unix, and with billion-dollar companies like Red Hat and IBM it's certainly a commercial endeavor at proprietary Unix's expense. It would seem to be an attractive target if a plaintiff like SCO could somehow move the case to the federal circuit (as none of the standard appeals courts have declared APIs copyrightable).


Reimplementation does not necessarily violate copyright. Copying does violate copyright (absent fair use). Like verbatim copying. Example, Google didn't have to use the “java.lang.Math.max(a,b)” header, but they did. They did copy because they wanted to leverage the existing Java developer base who would easily be able to develop for Android, without having to do the hard work of building their own ecosystem. Overall, Google copied the header structure for more than six-thousand methods.


That is exactly what reimplementation means in this context, creating a new implementation of an existing interface. And that is exactly what GNU Linux did. They copied a large number of system header files and created new libraries that implemented them. The copied a large number of command-line interfaces, and created executables that implement them. They extended them in the process, but the goal was to mostly preserve API compatibility.


How many ways are there to define max? Surely AT&T should turn around and sue Oracle for lifting max(a, b) from stdlib. Or maybe SCO will rise from the grave and try it again.


An infinite number of ways. Call it max(b,a) [i.e., reverse the order of b and a inputs]. But Google didn't do any of that. They copied.


The previous remark's point was that Java copied many C functions, inventions largely of AT&T and BSD.


I see the point, but that's "whataboutism." I also have no idea who owns the copyright (if anyone does) to stdlib APIs, and whether Oracle obtained license. Do you?


> (if anyone does)

There's no doubt that if it is established that APIs are subject to copyright, then someone owns copyright to the C standard library APIs. It's not old enough for copyright to have expired, and nobody has ever released the APIs to the public domain (because nobody ever seriously thought that such a thing would be necessary). Establishing API copyright as a real thing without broad fair use rights would throw into doubt the copyright ownership of a large portion of all software ever written.


You could call it max(b,a) but that would be fucking stupid.

People shouldn't have to write shit code cause judges are tech illiterate.


And just how is max(a,b) good code and max(b,a) bad code?


Because the alphabet goes a, b, c, not b, a, c. The lexical ordering is uniquely privileged both when reading and writing.


Code written for one will fail for the other, and negates the whole point of interoperability. Therefore the method signature should not be copyrightable


Beware interpreting copyright law with the assumption that interoperability is relevant. The law doesn't care.


copyright has a fair use clause, which states that one can decompile software to produce a derivative for the purposes of interoperability. This then must assume that any apis being implemented has to both fall under copyright (otherwise, this law does not apply to api), but also means that the law allows for the use of the api for the purposes of interoperability (and therefore, you cannot claim to have the sole rights to an api).


Beware interpreting interoperability as a form of fair use. I wish we could make that assumption, but I don't think it's warranted.


Copyright exists to protect artistic expression, not functionality. Functionality is protected by patents.


Exactly. I don't see what you are disagreeing with. The point is that in order to leverage Java's developer base as quickly as possible they made it possible for Java developers to essentially develop for Android without needing to learn a new syntax for all the APIs they already knew. That is why they copied.


Afaik there are several certified GNU/Linux derivatives.


I'm not seeing any [0]. Care to name one?

[0]: https://www.opengroup.org/openbrand/register/



Both EulerOS and Inspur K-UX are Linux.


Seems like it’s really just an excercise in lawfare. The underlying legal “principle” is flexible.


Is this akin to React vs. Preact? Same API, entirely different codebase. Allows me to drop in a replacement if Facebook does a stupid.


It does sound similar


Key line from the article:

"In a closely watched 2014 decision in the dispute, the Federal Circuit said the APIs were entitled to copyright protection."

Apparently, header files (which were subject to much discussion in the case) are still a legal minefield.


Considering the pain that has been caused by Google deciding they needed to reinvent Java, and do so in a way that isn't really compatible with the new releases, I would say I'm ok with this.


So you're OK with causing massive problems to anyone trying to provide alternatives to proprietary APIs just to stick it to Google?


Judges don't decide what's fair or ethical, they determine how disputed action intercedes with law.


I'm not commenting on the judge's decision, I'm commenting on s73v3r_'s position.


Most third party commercial Java vendors, selling JDKs for embedded development also have their own VMs and AOT compilers, with variations better suited for their hardware.

Aicas, PTG, IBM, MicroEJ, ....

Big difference with Google?

They play by the rules.


The rules as Oracle (and this ruling) sees them. Google and others disagree with Oracle about what the rules are or should be.


Interestingly, Microsoft briefed in support of Google this round in contrast with the copyrightability round.


> They play by the rules.

Or they will be sued out of existence. Google? probably not. IBM tried Harmony play along with Apache but backed away after legal threats.


All telecommunication companies, Nokia, Motorola, Alcatel-Lucent, .... have their network elements APIs copyrighted and pattented.

Try to sell a device that comunicates with a e.g. BTS station without buying their licenses, to see how it ends.


In my experience the big hurdle is getting your device certified, not licensing issues. That's not really an IP issue however, it's just that uncertified devices might misbehave and create issues for other users.


Mobile Telecoms standards are written by 3GPP, all BTSs and handsets (and for that matter, interfaces like 'A') are standard, and controlled by 3GPP. I believe they are open.


Not they belong to the companies and some of them are available under FRAND licensing.

For the rest there is the 3GPP patent platform.


I'd say it's patent law, not copyright law, that make the licences possible to enforce.

Most of the patents are the result of a lot of research and cleverness. Some of the patents are the equivalent of looking in another drawer if the first one did not contain what you are looking in.

It's a bit arbitrary that an API isn't protected when some bullshit patents are. There is clearly much thought in some of the java APIs.

I'd like to see shorter protection time for patents thought, especially in areas where there are very low investment costs, like software development.


>are we no violating their copyright just by implementing their API?

OpenJDK is GPL. If you comply with GPL, no. This is the problem, Google copied and did not comply with the GPL. Their other option was to pay Oracle/Sun a licensing fee for a commercial license. This is exactly the business model many GPL users follow. Ruling otherwise makes this business model invalid, but it also creates a double standard.

Consider a programming language where you program in types, like Idris. The case is more obvious here. The API is a program. The same applies to Java too, but that seems less obvious. The API is the program that produces compiler output.


Huh .. so why doesn't Google just release their Android Java runtime under the GPL? Seems like an easy win all the way around?

I thought the OpenJDK people needed certain concessions to release their VM under the GPL?


Supposedly, they are switching to OpenJDK. But that doesn't erase their past infringement.


This is exactly the business model many GPL users follow.

GPL users charge money for a license on the implementation, not on the API. Or do you know any charging a license for the API itself?


When Google did that, Google was relying on controlling precedents in the 9th circuit saying that APIs are functional elements needed for interoperability and therefore are not copyrightable. The first judge that they saw agreed with them and it should have been an open and shut case.

It was Google's misfortune that through a quirk of the system the case wound up in the Federal Circuit, which has a history of creatively ignoring precedent to fashion new precedent that increases its own importance. (Which is how we have patents on all sorts of crap that the Supreme Court has ruled that we shouldn't.) And it was good lawyering on Oracle's part to throw every possible argument at the case, including the copyright arguments that they knew they should have lost.


Google believed they could implement their own VM and get something cheaper (and/or better) than they would get by licensing one from Sun. That seems like a perfectly legitimate business decision for them to make. A clean-room reimplementation of an existing API had long been thought to be legally clear, going all the way back to Compaq reimplementing the IBM BIOS and starting the "IBM-compatible" competitive ecosystem that our whole industry is built on.


> better

That's it. The VMs on the market at the time we're absolutely terrible for phones. John Carmack was commenting on how JavaME gave you worse performance than an original IBM PC, and HotSpot's strategies absolutely destroy battery life.


Except that wasn't the only approach available.

There are OEMs selling commercial JDKs for embedded use, with their own VM, JIT and AOT compiler variations, and library extensions.

Contrary to Google, they always played by the rules.


The whole subthread focusing on the Android VM is completely irrelevant. The entire argument at this point has to do with the inclusion of the Java APIs. Not even Oracle or the appeals court are harping on Google's custom VM.


The VM is used as an excuse by Google supporters why they should get excused to help drive Sun into the floor.

Java still exists today thanks Oracle, not Google.


Android does not have a Java VM, and it does not run Java bytecode. Dalvik bytecode is more compact, and more CPU efficient, and the more recent ART runtime is even more efficient and performant. But it isn't a JVM.


Just like all the vendors selling commercial JDKs for the embedded market.

They also offer customized versions fine tuned for their deployment scenarios, doing Java bytecode to either native (AOT) or their own proprietary bytecode format when generating the firmware image.

Or for example, IBM Java running on IBM i mainframe, where Java bytecodes used to be translated into the TIMI bytecodes, just like any other IBM i application.


The Dalvik and ART runtimes differ in that the do not run Java bytecodes. Every commercial embedded jvm, open source jvm, and me jvm I have seen all run Java bytecodes and you can use any toolchain that makes .jar files with these vms. Unless the translation you mention can happen at runtime, it isn't a jvm.


It happens at deployment time, as mentioned.

Firmware does not change during runtime.


In 2008, none were as good as Dalvik for the use case.


That's the story Google likes to sell.

Nokia and Sony-Ericsson flagship phones were quite good.


No they weren't, I developed for them.


Me too, alumni from that little company located in Espoo.


I hope that little company does not come under pressure to make Android phones.


It is hard to compete against a free beer OS originally developed with tech unlawfully taken from other companies.

So one either swims or joins the graveyard of companies that tried to fight it.


> It is hard to compete against a free beer OS

I'd argue that it's next to impossible. OSes are a commodity now. Even Microsoft is coming around to that idea.

> tech unlawfully taken from other companies.

All of the previous caselaw said that this was fine.


I was third party. Maybe your close association is blinding you.


Google did not do a clean-room reimplementation. They copied. This is not disputed by Google.


They copied literally a handful of lines of code that an intern could have written in a few hours.


But they didn't just write their own APIs. They copied them. Thousands of them.


Copying an API is what software developers call "implementing an API"

When you create your own USB cable, or electric plug, you aren't copying the API specs, you're implementing them.


Once they admit to copying some of it, it throws the whole clean room process into doubt. I think the courts are working on the "where there's smoke there's fire" principle.


IYO did they copy an artistic work?


Copyright covers subjective work, not just "artistic" work. In the same sense that the choice of how to paginate a phone book and where to put the guidewords on each page is copywritable, yes APIs are copyrightable.


Google knew what they were doing and IMO they were right. I still don't think Google or anybody should have to ask for Oracle's permission for reimplementing a JVM (as long as it's done cleanly). You seem to put the blame on Google for not wanting to pay $100M at the time but what if instead it was a small startup who simply couldn't afford that cost?

I'm not worried about Google in the least, I am however concerned about the precedent this sets.


> what if instead it was a small startup who simply couldn't afford that cost?

Licensing costs can scale according to the customers business size and revenue. What is more concerning is that this may create precedent that API specs are copyrightable -- to the degree they are worth billions in damages.


Licensing costs are arbitrary. If you want to license some IP from me I can ask for a billion dollar for it. Or I can simply refuse to sell it. The point is that IMO Google or anybody else shouldn't have to ask for permission for cleanly reimplementing an API.

I think some people in this thread are minimizing the issue because they don't like Google but I think it's naive and short-sighted. It's not about Google or Oracle, it's about copyrighting APIs.


> I'm not worried about Google in the least, I am however concerned about the precedent this sets

It's legal precedential value is limited, because it was a copyright decision in the Court of Appeals for the Federal Circuit (CAFC).

The general principle for a precedent is that precedent for court X is set by the appeals court that hears appeals from X, and the appeals court that hears appeals from that appeals court, and so on.

So, for example, the district courts in the 9th Circuit (which covers the west coast tech companies) gets precedent from the Court of Appeals for the 9th Circuit, and from the Supreme Court. In particular, this is the appeals path for copyright cases.

The appeals path changes for a few special subjects. Patent appeals from all of the Federal district courts, for example, go to CAFC. So, in matters of patents, a district court in the 9th district would look to CAFC for patent precedent, not the 9th circuit appeals court.

Oracle sued Google for both copyright infringement and patent infringement. The parties were OK enough with the outcome of the patent part of the case that no one appealed that, but the copyright decision was appealed.

You might expect that this means the appeal would go to the appeals court for the 9th Circuit, because only copyright issues were being appealed, but that's not how it works. Where the appeal goes is decided by what was at issue in the original case, not by what was at issue in the appeal.

The rule is that if a case has both a special subject, such as patents, that points to CAFC, and other subjects, such as copyright, that point to the appeals court for the circuit the district court is in, the appeal goes to CAFC. CAFC handles the whole thing.

When CAFC gets a subject that normally does not come to them, but got there because it was attached to a case that also had a subject that does go to them, the rule is that they are supposed to follow the precedent of the appeals court for the circuit the district court is in. They don't set precedent in that district.

For example, if two companies sued over copyright in the 9th Circuit, with no other issues involved that would deflect the normal appeals path away from the 9th circuit's appeals court, the district could would look to that appeals court and the Supreme Court for precedent. CAFC opinions on copyright would at most be interesting opinions it might look to for insight, just like it might look to courts of appeals for other circuits, but only it's own circuit's appeals court and the Supreme Court would be precedent it has to actually follow.

PS: I think we'd be better off if CAFC just got the patent appeals. If a case has both copyright and patent issues, send patent appeals issues to CAFC and copyright appeals issues to the circuit's appeals court. At the trial level we merge cases that would normally be in different courts into one (e.g., if a case has both state and federal issues, it goes to federal court and the federal court handles the state issues).

That makes sense at trial court level because they involve examining witnesses, examining experts, and similar. If different issues were heard in different courts, many of those witnesses would have to go to multiple courts. It could be a major hardship on them. You'd want to hold them all in the same area, at near the same time, to minimize travel. That could be hard to schedule.

Appeals courts, on the other hand, just work off the transcript from the trial. The only people needed there are the lawyers arguing the case. The lawyers for appeals are usually more specialized than trial lawyers, so there are quite possibly different lawyers handling the different issues in the appeal.

It would not be much of a hardship, if any, for different issues to go to different appeals courts, as long as a little care is taken with scheduling.

Heck, it might even be less of a hardship. Imagine you are a copyright appeals lawyer in the 9th Circuit. Normally all your appeals court appearances are in the 9th Circuit, and you have a few cases going on there. Then some stupid mixed patent/copyright case comes along, and no you've got a case on the other side of the country to deal with.


Haven't all of the patent issues been settled? So what's to stop a copyright troll from adding ancillary patent claims to be able to use the CAFC for the appeals process from now on.


But, and this is the big but, they did it in such a way as not to be compatible with the Oracle one.


I'm not sure how that's relevant, if anything since the crux of the issue seems to be the "stealing" of the API the fact that there are incompatibilities should be in Google's favour? It's a bit odd to claim that somebody stole your API while at the same time complaining that they did not steal it well enough.


"I'm not sure how that's relevant"

The original license for Java said you can create your own implementation just fine, so long as it was compatible with the others (or at least the benchmark one). By not doing that, Google violated the license.

"It's a bit odd to claim that somebody stole your API while at the same time complaining that they did not steal it well enough."

Not if what you want to avoid is people Embracing your API, Extending it with new special bits, and Extinguishing your version.


That's not all it said. The license had field-of-use restrictions, meaning you couldn't use your implementation for every purpose. The Apache Foundation published an open letter to Sun on that regard.

And specifically, use of a J2SE implementation in mobile devices may have been forbidden.


> I think the part that gets lost in all of this is that Sun offered to license Java to Google previously for $100M. Google turned that down and bypassed Sun because they didn't want to pay (or license).

I'm not sure I follow - Google believed they didn't need a license, just like everyone who used Linux despite SCO offering to license Linux to them.

If Google needed a license, and Sun had not offered one, it would not make a difference; Google would still be liable for infringement. There's no abandonware or compulsory license provision in the laws for this. The question is whether Google needed a license, not whether Sun was willing to offer one and for what price.


There's no provision for compulsory licensing for copyright because it's not supposed to inhibit technical implementations. Patents do that, and it least in the UK the law includes compulsory licensing.


US copyright law doesn't do compulsory licensing for anything other than music recordings, and I believe it doesn't have compulsory patent licensing at all. I'm not sure there's a good rationale for this.


> My point is, they did this to themselves

Whether or not they knew that someone would come along and sue them doesn't matter if the lawsuit is unjust.

Even if Oracle is correct, and even if APIs can be copyrighted, Google's intent still doesn't matter. The only thing that matters is whether or not they infringed.

I consider this to be a form of victim blaming. You should argue the case on its own merits, not posit that Google was "asking for it."


It wouldn't be victim blaming to criticize a company that is breached because they didn't take compsec seriously. They weren't a small company at the time and they knew this was a hazard.

Google had a responsibility to their shareholders and customers to do the right thing regardless of how stupid they thought the law was, and their attitude here was pretty arrogant. (To avoid beating up on Google, I should point out believing they could take on anything helped them do some work that changed the world for the better.)

Since the attitudes of parties involved in a case are often considered in judging the case, I think it's entirely fair to bring them up.


> It wouldn't be victim blaming to criticize a company that is breached because they didn't take compsec seriously.

If you then turned around and argued that the hacker somehow wasn't in the wrong because of the victim's attitude, yes it would be.

Victim blaming has nothing to do with someone's responsibility to others, and everything to do with taking a conversation about whether an attack is justified, and shifting that conversation to instead suggest "well, dumb people like that deserve to be taken advantage of."

Oracle contested that Google infringed their IP. "They should have known we were gonna sue them as soon as we smelled the money" is not compelling evidence for that claim.

Much in the same way, saying "Johny should have turned off his attitude and just given us the money" is not compelling justification for a mob hit.


Call me naive, but is a company being happy with what you're doing to the tune of them even saying so (or representatives thereof) tantamount to an implicit contract? I know it's been argued in this case, but it strikes me as disingenuous at the least and fraudulent at the most to change your mind. Sure we don't mind Google bearing the brunt of this because they can, but how would we feel were a smaller company subject to this kind of bait and switch based on legalities?


It's not a contract, but there are other mechanism in the law to give effect to this intuition: https://en.wikipedia.org/wiki/Estoppel


Estoppel: This my be my new favorite word. I can imagine all kinds of scenarios for use (okay, I can imagine one) "You can try to renege on your promises, but I'll estop you, I'll estop you once & for all!"


This isn't a bait and switch based on legalities. If Oracle made representations to Google that they didn't mind them using their software, Google would be able to claim that Oracle is estopped from pursuing a claim due to the prior authorization they received.

What's being stated here is that Google's infringement improved Oracle's market position - that fact doesn't bar Oracle from pursuing their remedy against infringement. If you steal my software for making phones chirp every time you get a tweet and widely distribute it to the point that it becomes the de-facto standard in the tweet notification market, it doesn't magically mean that I don't get to come after you for stealing my tweet tech.

Here's the decision itself. Estopple is mentioned 0 times. This isn't because Google's legal team is braindead. It's because the argument that the Google's use was authorized following them walking away mid-licensing negotiation is insane. Google's defense is based on fair use. http://www.cafc.uscourts.gov/sites/default/files/opinions-or...


I am not sure you are familiar with the entire case regarding Sun's public approval of Google's Java use. Oracle argued it was the CEO's personal blog, but the CEO definitely did give a form of "green light" depending upon your interpretation. It's a defense I feel like is easy to do against a large company that "should have known better", but would be considered unfair against a smaller company that was essentially given approval. I won't address the rest of your comment that is out of context since it's missing this important fact.

Here's some old HN discussion on it: https://news.ycombinator.com/item?id=2806771


I'm familiar with the case. The comment isn't out of context; you (and other posters) need to recognize that IP rights are composite rights, like real estate.

In real estate, you can own a plot of land and provide others with permissions associated with the land; maybe they're allowed to walk over a path that runs through your land. That permission is not equivalent to all possible permissions associated with the land - although maybe some ancillary ones are implied in. Maybe people are allowed to bike over the path too, but they certainly aren't allowed to dump broken washing machines there.

Similarly, in IP I can grant you a set of rights related to my product without giving you ALL rights related to my product.


To use your own analogy it seems like we are only talking about one singular right. Making derivative work thereof. If not can you clarify your position?


They did make those representations, and Google did claim that.

https://arstechnica.com/tech-policy/2016/05/suns-jonathan-sc...


No, they didn't.

If I hand you a bag of balls and say you're allowed to play with the purple and green balls inside, I haven't given you permission to play with any of the other balls.

In this case, the different balls are the different dismemberments/rights related to Java.


Sun defended Java with the trademark and the compatibility kit, not copyright on the API. It never occurred to anyone (as it shouldn't now) that there was copyright on the API.

[edit] Jonathan Schwartz: "The strategy was, we agree on these open APIs, then we compete on implementations."


> If you steal my software

Nothing was stolen (i.e. Oracle still has the software), it was an infringement of copyright (and perhaps patents).


That licence would have more restrictions in both the short and long term than just the upfront cost.


I'm having flashbacks here, but what I remember at that time was concern that if Google paid Sun, they'd be setting a precedent that way. There was a sigh of relief when they didn't, at least from some, because, regardless of how much better of a company Sun was than post-Sun Oracle, people felt like it was overreaching.

So although you're correct that Google did this themselves, the alternative was fraught with problems also. Better to fight it and lose than implicitly accept the idea and pay.

This was all happening in the context of C#, which people seem to be forgetting about too. It's important to remember that the whole idea of copyrightable API was done under the argument that it was important to protect API integrity from forks. MS provided evidence of a desire to do this (as has Google to some extent since then) but then introduced C# instead.

Anyway, this is a mess because copyrightable API is ridiculous, but Google should have been more careful with cleanroom implementations.


It's also very standard enterprise thinking: Save 100 mio now, get a bigger bonus check, and worry about the consequences later. Maybe all consequences can be avoided even.


To complement that, here is the most recent Gosling´s interview at Triangulation about how Google screw Sun and was aware of their monetary situation.

https://www.youtube.com/watch?v=ZYw3X4RZv6Y&feature=youtu.be...


Well, first Sun treated Apache like shit over Harmony issue which had such big role in popularizing Java. Later Sun was was on receiving side.


SUN wasn't very happy about Google using Java without paying anything. IIRC SUN wanted Google to use J2ME and get some modest fees; instead Google decided to reimplement API, pissing off all top guys at SUN who publicly were OK with it (hoping they could negotiate some payment), but internally were boiling.


I don't think J2ME was suitable for googles usage regardless of price. Unsuitable tech is unsuitable if someone pays YOU 100M


Sure, I also found it funny back then, but that was what SUN management was thinking...


Sun was only incrementally better than Oracle in their approach to Java licensing. They already has one pyrrhic victory over Microsoft that birthed C#, .NET, and Microsoft's own VM. Failing to come to terms with Google means client Java runs on Android, and not even on a Java VM. Way to make your language technology relevant.


Sun didn't just license the rights to the Java IP, but as a supposed standard established by the JCP, a farce of a standardization body that never was.

Google probably had to use their implementation and J2ME was and still is a piece of shit.

Yes it was about cost, but the cost would have been far greater then the licensing price ;-)


I wonder how the $$ Google might pay to Oracle compares to the $$ it is spending to move away from Java by building replacements (v8, Go, Dart, Flutter/Fuschia, etc.) that are all essentially "GC languages with a great runtime VM".

E.g. I can understand Oracle/Sun needing some amount of money for stewarding Java, as the teams required to build/maintain/QA/release the JVM were AFAIU in the hundreds, so not cheap. But "Java is free", so they didn't have a way for covering that cost from the majority of enterprise developers who were getting a free lunch, and instead relied on the J2ME licensing almost by accident/happenstance IMO.

So now, companies like Google are not "paying for hundreds of Oracle/Sun engineers to develop a platform/language/ecosystem", but instead "paying hundreds of internal engineers to develop (multiple) platforms/languages/ecosystems".

Which they can do, and still provide v8/Go/Dart/etc. "for free" because they have the luxury of paying for everything with ads, which Oracle/Sun didn't, which forced Oracle/Sun to commit the sin of asking for money.

Granted, don't want to be an Oracle/Sun apologist b/c they messed up in a lot of ways (stagnated the language/etc., don't have a great reputation, etc.) and the competition/iteration of the next-gen languages like Kotlin/TypeScript/Go/etc. is working out great.

Just interesting to think of the economic trade-off, e.g. if Oracle had been a little less controlling, and Google a little more willing to pay licensing/something, if the net effect would have been Java today being in a demonstrably stronger market position than it is.

And, either way, the rest of us are still being spoiled by so many free lunches: amazing tech (languages/libraries/frameworks/ecosystems) built by professional teams that we don't pay a dime for.


V8 has little to do with Oracle, fundamentally. V8 came about because they wanted a higher performance JS VM for their browser; the JVM was never in contention there.


Though it has little to do with the parent post's point, technical development of both V8 and HotSpot was led by Lars Bak.

V8 didn't come about because of the JVM, but it was done by the same guy who wrote the JVM.


Sure it does. Why did they want a higher performance JS VM for the browser? The language of choice to build interactive applications on the web before JS was really viable was Java.

A high performance JS VM means we don't need to use applets anymore.


This is ignorant. The rise of Javascript had little to nothing to do with the fall of Java applets, which failed due to their own issues.

Java applets were already considered a dying tech when Google made their push to heavily-Javascript-dependent apps, and the performance requirements that led to.

Note also that despite the similar name, Javascript and Java have technically nothing to do with each other. It is a quirk of business history [1] that Netscape and Sun partnered to name Javascript as it is when Sun was first pushing Java as a web technology.

[1] https://en.wikipedia.org/wiki/JavaScript#Beginnings_at_Netsc...


The original use of JavaScript was to pass DOM information to the applet and back. https://docs.oracle.com/javase/tutorial/deployment/applet/in... and https://docs.oracle.com/javase/tutorial/deployment/applet/in... are the docs for this largely forgotten functionality.


There was no DOM back in the early days of Javascript. The page was rendered in a single pass, you could inject text and markup via document.write() and anything "dynamic" was accomplished by reloading an IFRAME. Remember, these were the days when too many tables would crash your browser; I recall the early demos of Gecko showing deeply nested tables, and all styling was with font tags still.

Netscape was still trying to sell a browser, and they wanted a common language on the frontend and backend, so Javascript was also on Netscape Server.


Maybe the 'DOM' wasn't the right word choice. However, in 1995 one could foo = document.getElementById and foo.innerHTML as described in https://docs.oracle.com/javase/tutorial/deployment/applet/in...

It was possible to call JavaScript from a Java applet and method in a Java applet from JavaScript (on a web page).

This functionality can be seen in Java 2 (now known as Java 1.2) - http://www.oracle.com/technetwork/java/basics-137133.html .

https://en.wikipedia.org/wiki/Netscape_(web_browser)#Release... has JavaScript and Java as part of the same release for Netscape. The next release of Netscape Navigator (3.0) had LiveConnect version 1 ( http://web.mit.edu/javascript/src/mozilla/js/src/liveconnect... ) which was that cross language communication.

I would be willing to contend that in the view of "Java applets are where the web is going" back then, the difficulty of communication between the applet and the enclosing page was something that needed some scripting glue and that JavaScript, from its inception, was to be that glue. It took about a year to get it working, but this was the initial goal of JavaScript.


By the early years of Google applets were already pretty much dead:

https://www.javaworld.com/article/2076251/core-java/applets-...

(Note that the article is from 2000.)

Remember that Google was already doing AJAX in Gmail in 2004, years before V8.


And V8 was first released in 2008. Java applets were pretty much completely gone from the web by this point. The only competition on the web, from plugins, at that point was Flash (okay, Silverlight deserves a footnote, but little more).


V8 is ten years old?! How time flies...


I have the opposite response: only a decade old? Same with YouTube actually, I can't really remember what the Web was like without video streaming


There was streaming before. You installed Real Player so you couBuffering...


> The language of choice to build interactive applications on the web before JS was really viable was Java.

I find this amusing. No one ever built anything meaningful client-side with Java. There's a reason Microsoft laughed off Java as "write once, debug many".


Um Eclipse? Netbeans? ArgoUML? (just out of top of my head).

Your statement would be true if you have said "anything meaningful client-side on the web with Java". On the web Java was restricted to Java applets and was never really in competition with JavaScript.

Desktop is quite another story.


Agreed, my context was browser specific applets. Clearly Java has some moderate success on the desktop.

I do think Sun entertained Java superseding Javascript in the browser - it just didn't work out that way.


Java applets were huge, and still are quite big in enterprise.


Where? We're not talking servlets or EJBs here right? Adoption across combination of OS & browser was and continues to be an issue.

Both Microsoft and Apple made it difficult in different ways, and the "year of linux on the desktop" has yet to really come (no ChromeOS don't count)


"Adoption across combination of OS & browser"

Not a problem when everyone is using Windows and Netscape. It's as horrible as you'd think.


Not Flash? In my experience Java applets never got anywhere close to the level of adoption of Flash. I suppose it might've been different in corporate environments. I had Flash enabled in my browser long after I stopped using Java applets altogether, if only for video streaming.


Corporate environments were different (easy was to expose Java business program to user without hiring Web people), but the doom of Java in the browser was the whole applet concept and not the DOM integration that JavaScript had. It might have been quite a difference if the JVM could have controlled the webpage like JavaScript.


> The language of choice to build interactive applications on the web before JS was really viable was Java.

Actually, Java was already mostly dead for the public web when Chrome and V8 were being developed, it was more Flash that was the competition.


Sorry, but for the web java applets were never viable and universally complete garbage.


Gah, I'm an idiot and replied to the top-level thread instead of here. See my "I agree it seems that way" comment down below.


In underlying code you are correct. But they both work in a C/C++ style. JavaScript has become a 'Write Once, Run Anywhere' foundation because of the web browser. Don't forget projects like NWJS (Node Webkit), Electron, Cordova/PhoneGap, Google Chrome Apps, NodeJS, and ClearScript(.NET).

All of these JavaScript implementations use the V8 JVM and can make desktop and command line application. Depending on security settings they can give partial to full system access to the underlying OS just like Java. If this ruling is upheld I would look for Oracle to float a trial balloon on newer JavaScript implementations and for stealing their Java's API's.


> All of these JavaScript implementations use the V8 JVM

V8 is not a JVM (Java Virtual Machine), but a virtual machine for Javascript.


V8 is not a JVM. It's a JS VM / ECMAScript VM. Java and JavaScript are not the same language. They are not even directly related languages.


> And, either way, the rest of us are still being spoiled by so many free lunches: amazing tech (languages/libraries/frameworks/ecosystems) built by professional teams that we don't pay a dime for.

Don't those things realistically exist precisely because of a virtuous, continual cycle in the greater tech community of paying that free lunch forward?

Even the strictly free lunch use cases, where someone doesn't contribute time/money/effort back into the system, involve helping to popularize the whole and keeping it going; broadening it, spreading it, bringing more contributors in. Those people end up as popularizers/evangelists, which is a required ingredient for the virtuous cycle to keep going.


In some cases that's probably true. But consider how few resources were devoted to Openssl before they ended up in the limelight.


I think the case was basically lost as soon as the court ruled that APIs are copyrightable. I still disagree with that decision, but once you've already arrived at that point then I think it's pretty hard to argue that Google's use of those APIs was fair use.


Why can't they appeal that ruling? It's completely wrong. EU got it right, and copyright lobby didn't manage to spoil it there.


They did appeal, and the Supreme Court pretty much said they didn't want to look at this until a trial took place on the fair use question. Now that that's happened, I assume there will be another appeal to the Supreme Court.


I sure hope so. That decision definitely needs to be appealed. I very much hope it's overturned. (The industry has pretty much assumed - and acted - that APIs were not copyrightable, and that's worked out all right. Suddenly shifting to APIs being copyrightable is going to cause some change the rules under existing activity, in ways that it's hard yet to define the full scope of.)

But even if it's not, the decision needs to be appealed. Right now the situation is that APIs are copyrightable, but only for sure within one of the US Federal Court districts. In the other districts, they may be copyrightable. Or they may not be. If they aren't, then we have different law applying in different districts until the Supreme Court decides to resolve the issue. A Supreme Court decision now, one way or the other, would at least give resolution. (If they decide that APIs are copyrightable, then we'd have different law in the US and Europe, but at least it would be the same law everywhere in the US.)

[Edit: Apparently this isn't in a district court, it's in the Federal Circuit, which handles patent cases.]


> Apparently this isn't in a district court, it's in the Federal Circuit, which handles patent cases.

This is a very important nuance. As I understand it, for the issues in this case that are outside the Federal Circuit's usual jurisdiction (patents), the Federal Circuit was supposed to rule however the local circuit (Ninth) would have ruled. The Ninth Circuit probably wouldn't declare APIs copyrightable, but the Federal Circuit did.

However, the Federal Circuit doesn't establish binding precedent for the Ninth Circuit on non-patent issues. That's part of why the Supreme Court didn't take up this case, and why many of the amicus briefs recommended against the Supreme Court taking up the case. Google gets screwed, but that ruling didn't have cause an immediate upheaval of copyright law in the jurisdiction that includes Silicon Valley and Redmond. All that their decision really established was an incentive to include bullshit patent claims in any copyright suit that pertains to APIs, so that you can get your appeals heard by the Federal Circuit instead of your local circuit.


Didn't White House administration try to interfere with this case, and persuade judges not to declare APIs non copyrightable? That was really weird.

https://arstechnica.com/tech-policy/2015/05/white-house-side...

I wonder what will happen this time.


That's an interesting way to characterize it.

When the Supreme Court was considering Google's petition to hear the case, the court asked the White House to voice an opinion—where by "White House administration", you mean the Solicitor General.

That's not "weird"; that's a normal part of the job.

https://en.wikipedia.org/wiki/Solicitor_General_of_the_Unite...


The weird part was in their view on copyrightability of APIs.


That's not weird, either. What would have been weird is a finding that they're not copyrightable, given that it would have been completely at odds with the statutes and case law we have concerning copyright.

The point is, nuance matters. If you're physically attacked and defend yourself in a way where you end up killing the guy, you claim that your actions were justified. You don't go to court claiming that killing people is just not a problem.

Here's how this case should go:

0. Oracle sues Google for copyright infringement.

1. Courts find that the design of APIs is an expression resulting from substantial creative decisions far above the low bar we already have for precedent, and therefore they're copyrightable.

2. Google defends themselves on the claim that, creativity notwithstanding, merely implementing a public API should not subject an implementor to the consequences of copyright infringement, and that there are no damages owed here.

And by every indication, we're right on track.

https://news.ycombinator.com/item?id=10949839

And it looks like you're moving the goalposts and shitting out two-second replies, anyway, so I'm done commenting further here.


> What would have been weird is a finding that they're not copyrightable

Nothing weird with that. APIs are meta tools, not actual tools. That's what "I" in the name is for. They are interfaces for a reason. It makes perfect sense for interfaces to be non copyrightable. EU courts got it right:

    Computer code itself can be copyrighted, but functional
    characteristics—such as data formats and function names—
    cannot be. "To accept that the functionality of a
    computer program can be protected by copyright would
    amount to making it possible to monopolise ideas, to the 
    detriment of technological progress and industrial 
    development
> And by every indication, we're right on track.

We are not, until Supreme Court will overturn the current ruling and will clear APIs from copyrightability for good.

> I'm done commenting further here.

Sure, you brought no arguments to defend the illogical position of APIs copyrightability anyway.


> Here's how this case should go

[...]

> And by every indication, we're right on track.

You're leaving out the step where the district court found that APIs aren't copyrightable, but the district court was overruled by an appeals court that normally has no right to rule on such matters and does not set binding precedent on such matters. If Oracle's now-dead patent claims hadn't been included in their original complaint, then the process you describe would likely have ended Oracle's case at step one with the Ninth Circuit upholding Alsup's ruling on API copyrightability.


First: No, I didn't leave anything out. Review the link I included in my last comment. Hold on to the Federal Circuit as a personal stick in your craw if you want, but I didn't leave it out.

Second: That's a stretch. To argue that the case would have stopped at the Ninth Circuit is to argue that because the Supreme Court denied Google's petition to reverse the Federal Circuit, then they would have denied Oracle's petition to reverse the Ninth Circuit. That's a junk argument.


> To argue that the case would have stopped at the Ninth Circuit is to argue that because the Supreme Court denied Google's petition to reverse the Federal Circuit, then they would have denied Oracle's petition to reverse the Ninth Circuit.

That's not the argument I'm making.

The Supreme Court had several procedural reasons for not granting Google's petition for certiorari: the Federal Circuit's decisions were not setting binding precedent outside of this particular case, and there were still issues to be decided by the lower courts that included avenues for Google to prevail, making it unnecessary for the Supreme Court to render a landmark decision on the matter of API copyright.

If the appeals had gone to the Ninth Circuit, Google's appeal would have stood a much better chance than it did before the Federal Circuit. A Ninth Circuit decision in the matter would have set a very important precedent, but a decision in favor of Google would not have created any obvious circuit split and wouldn't have upset the status quo of the software industry. On the other hand, a decision in favor of Oracle would potentially have consequences serious enough to be a priority issue for the Supreme Court whether or not it created a circuit split.


> A Ninth Circuit decision [...] in favor of Google would not have created any obvious circuit split and wouldn't have upset the status quo of the software industry.

Go on, finish the thought, and make your conclusion explicit. Because by any reasonable reading, you're suggesting that the Supreme Court would not have granted Oracle's petition if Google prevailed in the Ninth Circuit. And yet you start by saying that this isn't your argument. Be explicit.


It's a shame that there was no one like judge Alsup in the appeals court.

Now it's about legal phrases and licensing terms instead of common sense all over again.


Unpopular opinion: I feel Google should be punished for what they did to Java.

Maybe the mechanism being used is wrong, but Android bastardized Java and as an Android developer I feel real damage has been done to the health of the Java ecosystem by having billions of devices run fragmented Java-but-not-Java.

Google has started to make it right with the switch to openJDK and Desugar, but in a lot of ways it’s too little very late.


Java was only popular in the first place because people assumed it was a free-enough language that anyone could implement. Everyone assumed the TCK license was a technicality right up until Apache Harmony was (entirely unreasonably) denied one; most of the JCP members expressed shock and dismay at that.

That was the decision that lead to Android being "Java-but-not-Java". If they'd been granted a TCK license like they should've, they'd've implemented proper Java (confirmed by the TCK) and we'd be in exactly the same situation as if Google had used OpenJDK all along.


> real damage has been done to the health of the Java ecosystem by having billions of devices run fragmented Java-but-not-Java

Even 100% running with that, damaging an ecosystem isn't against the law. You could argue that Google damaged the Erlang ecosystem by not basing Android on Erlang. Ecosystems compete with each other all the time, and it's hard for one to grow without damaging another.


I didn’t say it’s against the law, or imply it. If anything I implied the opposite with the comment about the wrong mechanism.

Actually my mistake, I assumed that you mean copyright, if you mean all laws in general, I feel there’s probably a way for Oracle to litigate, similar to how J++ went down


Android arguably saved Java by making it much more relevant than it otherwise would have been.


I’m don't agree with that, the big reason why what Google did was so vexing was the timing.

Java was just starting to get revitalized after a long period of stagnation. Java 7 was a big deal and for a long time Android devs were limited to a weird amalgamation of Java 6 and a few Java 7 features.

Then Java 8 came with lots of great Stream goodies (and a lot more) while Android devs are still forced do to make due with unofficial backports or cutting off most Android devices (API 24) is the first to support them natively.

Android development gets mindshare for Android, not Java. The speed of the transition from Java to Kotlin shows how antsy devs were to get away from Java.

There are interesting things happening with Java, and they’re all outside of Android


> Java was just starting to get revitalized after a long period of stagnation. Java 7 was a big deal and for a long time Android devs were limited to a weird amalgamation of Java 6 and a few Java 7 features.

Counterclaim: If it were not such a big legal hazzle, it would have been a lot more easy for Google to update to new Java versions fast on Android.


Counter-counter-claim: No, it wouldn't, because Google screwed the pooch with their update mechanism. The reason people were faced with the decision of not using the new features, using unofficial backports, or cutting off older devices is because Google could not update their devices in a reasonable manner.


How so?


Just to give examples that look plausible to me: Because of the legal burden Google decided to implement their own version of the Java standard library based on Apache Harmony. With every new version of Java coming there might be new legal pitfalls to consider and surely almost always the sword of Damocles that Oracle might consider the fact that Google implemented new Java features as a reason to extort more money from Google since they implemented additional copyrighted APIs.


But they’ve already went and switched to OpenJDK.

Apparently the risk was not so large they couldn’t do it if they’ve decided to now


Legal burden or trying to save money? Didn't they get a license offer for $100M? Maybe they could've negotiated it down.


So true. Java 8 could have been as big a deal as perl 6, if not for those meddling kids.


Whaaa? I mean Java is undoubtedly more popular because of Android but it's not like it was hurting before. Sure, there aren't a lot of consumer-facing applications running Java but it's pretty much the standard on the enterprise side of things.


Java on mobile was (virtually) dead before Android. Now it's thriving and relevant again.


It was thriving in Europe, on flaghship Nokia and Sony-Ericson devices.

SavaJe OS was going to be the next generation when Android came into the scene.

Android first architecture diagrams look quite similar to the initial SavaJe OS presentations.


SavaJe went bankrupt two years before Android was released.


And who bought their assets? Sun.


After Android was released. And after the IP assets had been laying around on the market more than two years.

Sun buying SavaJe was pretty clearly a response to Android, so it's pretty disingenuous to say that Android killed SavaJe.


Apparently we live in different timelines:

1999 - SavaJe is founded

2006 - Jasper S20 with SavaJe OS gets presented at Java ONE

2006 - End of the year, SavaJe fails to gain another round of investment, in spite of the successful reception at Java ONE

2007 - April, Sun public announcement to buy SavaJe assets

2007 - November, Open Handset Alliance is created

2008 - November, HTC Dream gets released as the very first Android device. The initial architecture diagrams have a certain resemblance with SavaJe ones.

The OS that came to be Android started in 2003, was initially based in JavaScript, had lots of time to inspire on Java stacks after they pivoted to Java and were eventually bought by Google.

Only after SavaJe was no longer around, it became public what Google was up to regarding their mobile OS strategy.


Why are you comparing the date of SavaJe's being acquired, with the date of Android being actually released or gaining third party external hardware partners? Apples and apples would be Google's acquisition of Android in 2005 vs. Sun's acquisition of SavaJe's in 2007. And even then, Google acquired the actual devs too, whereas Sun only acquired the code and IP.

And Android is way more a rip off of Palm than SavaJe. All of the interesting things it does (the intent system, the capability based IPC, the battery friendly process lifecycle model, etc.) clearly descend from Palm (which isn't a surprise given that's where Dianne Hackborn cut her teeth).


J2ME was king on mobile devices in Europe (at least). Moreover, SUN had licencing fees from J2ME and if I remember correctly, you could not use Java on mobile devices without paying fee to SUN. So, it was their source of income and Google abused that. Just check interview (many times referenced here in comments) with James Gosling to see what the feelins on SUN side were. At that point, they were already underdogs compared to Google. This is all about greedy Google business behaviour and I think with Oracle they just got nice sparing partner to play legal war games with. SUN was too nice for them.


Java on mobile was (virtually) dead before Android. Now it's thriving and relevant again.

Perhaps, but is that a good thing if you're Oracle? Especially considering the fact that it's Google Java that's thriving and not Oracle Java.


It seems to me that it's a good thing for Oracle. Oracle/Sun was never going to make any headway in the mobile space. It just wasn't going to happen. So, it wasn't a loss to them, because they had already lost that market.

But, with Android, Java got a boost that bled over to the server, and to a lesser extent, the desktop. It can be argued what the size of that boost was, and if it had any real impact (I would argue that it was not significant), but it was still a boost that they never would have had.

Anyway, that's the opinion of some random guy on the internet.


Java was already king of the enterprise server long before Android happened.

Around 2006, many companies were moving their server stacks from C++, considered old and stagnated, into Java application servers.

I took part in several such projects.


But isn't that the point? That Google uses the Java infrastructure, but when it comes down to licensing, it isn't Java anymore? Google made a business decision to not buy a license and time will tell if that was a good decision or not.


What is it with all these ignorant but highly opinionated folks seemingly astro turfing for Google? Java remains very strong on the server side and it hardly needs Android to "save" it.


Android popularity (or demise) does have 0 impact on server-side Java. We don't share the toolset, we don't run the same JVMs etc. Call it Jiva if you like.

Google should go Kotlin way, it will be better for everybody.


The court isn't going to care if what Google did was damaging to the Java ecosystem. They only care if Google broke copyright law. Also, all software stacks are fragmented. Consider the alternative - some kind of machine overlord dictatorship ;)


They made billions of people access and use technology. Java was just a tool to help them achieve it. Sorry, your complaint is not really making sense here


It’s like I have a brand that makes widgets and gives out the plans to our widgets.

Larry finds plans to one of my old widgets and builds it into his awesome product and millions of people learn how to use the old version of my widget.

But my old widget kind of sucks and I’ve been releasing new widgets that fix a lot of issues.

Millions of people are gnashing their teeth over the old widget but Larry won’t update which version of my widget, he’s occasionally using parts of my new widget blueprint so now he’s creating Frankensteins of my widget that don’t even have a version.

But they’re still my widgets, Larry calling them by my brand name, people are conflating them with my widget, people making tools for my widget now have two diverging targets. People are saying my widget sucks because of issues I fixed ages ago.

It almost reminds me of J++ in a way, but with more subtlety.


That sounds like a trademark complaint, not a copyright issue.


Well if you look at my comment I mention this being the wrong mechanism for them being punished


So you want Swing apps on Android?


Someone flagged the comment before I could post my response, but here it was (re: Google didn't save Java on the client):

Java on the server was not in decline, but Java on the desktop was declining, had declined. Applets were dead, very few success stories around Java Web Start. And the main three 'consumer' success stories for Java on the frontend were Limewire, Minecraft, and IntelliJ/Eclipse. As a consumer facing technology, Java was a complete failure. No sane person wanting to ship a commercial, consumer app to end users would consider Java as a first choice. I have been a Java developer from the day HotSpot Alpha was released, I say this as someone who loves the platform.

Personal Java failed. I worked for years on J2ME apps, Java on high end Nokia Phones, Java on Palm devices (Ghost VM), etc. All these platforms amounted to nada. Flash was far more widely used for front end user facing apps than Java. Ditto for Visual Basic.

The relevance of the Swing comment is the people complaining about the fragmentation of Java's write-once-run-anywhere promise, which was always more of a promise than a reality. If you want to make a viable mobile Java, you had to remove Swing, Java2D, CORBA, JMX, and a ton of other JDK libraries, which is exactly what Sun did with the various profiles as well. But once you do that, you have "fragmentation"

If Google had not produced Android, I can bet the leading platform today for mobile development that is not from Apple, would either be Xamarin based C#, or some scripting language like Lua or Python on top of a Linux widget toolkit. Java would not be in the mix at all. Or perhaps it would FlashMX sitting on top of Linux (ugh)


> Android bastardized Java

> I feel real damage has been done to the health of the Java ecosystem by having billions of devices run fragmented Java-but-not-Java

Your feelings are not a legal basis for punishment.


Did I say they were? You’re patching into the use of the word feeling.

This just seems like a replay of J++. No one outside of Oracle or Google can determine the facts behind those statements you quoted, so the best outsiders like us can do is go based on “feelings” based on basic reasoning


>Google has started to make it right with the switch to openJDK and Desugar, but in a lot of ways it’s too little very late.

What functional changes accompanied Google's switch to OpenJDK? Doesn't Android still use its own incompatible VM?


Its not the courts purpose to ensure the health of the java ecosystem its purpose to decide what the law is now and going forward.


Java was literally dying before Google released Android. It was just something you did if you were in university or working on a legacy system. Everyone was moving to Ruby, JavaScript, and C#.


I don't think so: https://trends.google.pl/trends/explore?date=all&q=%2Fm%2F02...

From that you see that interest in Java is slowly declining since 2004, release of Android didn't even move it up a bit.


Look again. The downward trend of Java was arrested and it stayed on a plateau when Android began becoming popular; then come 2015 they both came down together.

If we're using Google Trends as a proxy for what happened, then I'd say there's some truth to Android saving Java from its decline.


On the other hand, Java was on a decline before Android, and since then it's more popular than ever. Just think how many new developers have had to "learn Java" just so they can build Android apps.

I understand the fragmentation issue, but I think it's a minor one and the net benefit for the Java ecosystem was much larger.

Also, Oracle is simply in the wrong trying to copyright APIs, and it has gotten a lot of hate from developers over that + all the other things they've done to Sun's previous projects that also made developers hate them.

With its developer-hostile attitude, is it any wonder developers are no longer interested in having anything to do with Oracle?

https://www.techrepublic.com/article/oracles-lack-of-develop...

Like what is this nonsense from the article:

> Oracle said its APIs are freely available to those who want to build applications for computers and mobile devices, but draws the line at anyone who wants to use them for a competing platform or to embed them in an electronic device.


This argument that Java was dying before the arrival of Android is super suspect. At best, you could say java was stuck in a rut between 6 and 7 (similar to c++ up until c++11), but it’s industry usage had not waned.


from TFA: "Oracle claims Google was in such a rush in the mid-2000s to create an operating system for mobile devices that the company used key parts of copyrighted Java technology without paying royalties. "

If this is true, it certainly isnt happening again. Google dominates smartphones and could very easily decide to phase out java for go/rust, torpedoing whatever rent-seeking strategy Oracle had originally devised. What oracle is attempting to do is nothing short of what Microsoft tried to do with TomTom's implementation of FAT.

If BTRFS, percona, and maria are any indication its not the work that matters. Plenty of talented engineers are willing to devote their time and effort to avoiding Oracle. Quite frankly the Oracle Database has turned into a manacle for Ellison. Unable to prevent its inevitable loss to open source alternatives through NDA agreements that prohibit public release of independent Oracle performance tests, and unable to convince cloud-bound companies to continue forking out high dollar per-core licenses for it, The software exists as a 90s anachronism to the hubris of dotcom. Oracle Enterprise Linux was, for all its intentions, a flop, and after acquisition and rebranding MySQL is a withered husk compared to its open source counterparts.


> The software exists as a 90s anachronism to the hubris of dotcom.

The point is that in BigCo environments the norm still is "no one ever got fired for buying IBM and Oracle" and even if that were not true shitloads of enterprise crapware are bound to Oracle's offerings and that alone will secure revenue for Oracle for decades to come. Hell when I look at the average age of stuff in the banking and insurance sector I would not be surprised if Oracle is still going strong in a century.


> torpedoing whatever rent-seeking strategy Oracle had originally devised

They will get damages for everything that has already happened if they win, which is more than zero, so they do have a clear profit motive.

Oracle gains nothing by having Android use Java so if they force Google to use something else it doesn't matter to them.


"If this is true, it certainly isnt happening again. Google dominates smartphones and could very easily decide to phase out java for go/rust, torpedoing whatever rent-seeking strategy Oracle had originally devised."

Because wanting to be paid for one's work is "rent-seeking" now?

And no, Google really couldn't. There's a huge library of Android applications that are using Java technologies to make them. Google can't replace Java with go/rust/dart without throwing all that away. They would have to continue to provide support, which would continue to put them in violation.


Just because you worked on something doesn't mean you get a perpetual government enforced monopoly on it.


And just because you want something doesn't mean you deserve it for free.


The question of API copyrightability seems to have been a big failure of the legislation-and-precedent system.

The theory is that instead of the legislature trying to think through all the corner cases ahead of time, they pass a somewhat vaguer act and leave the courts to sort out some test cases; then in a reasonable amount of time clarity is supposed to emerge.

But it's been 40 years since the world decided that it would "protect" computer programs as if they were literary works, and 30 years since most people thought that the question of API copyrightability was settled, and it turns out that we never got clarity at all.

Having judges trying to determine the question by deciding whether APIs are analogous to chapter titles or plot points in Harry Potter books is just ridiculous.


I'm conflicted on this.

A. I don't like that APIs are copywrite-able.

B. I wish Google complied with the GPL anyway. I hate this anti-GPL sentiment that has been going around the last 10 years or so.

C. The android play store would probably go through a renaissance if all the apps had to be rewritten.

D. I don't trust Google, but I really really really don't like Oracle.


B. Java is not licensed under the GPL.

C. Not going to happen.


B. Java is not licensed under the GPL.

OpenJDK is.


OpenJDK didn't exist when Google developed Android, so it would have been very hard for them to use it.


The first commercial release of android was 2008, the first release of openjdk was 2006. It wouldn't be that hard to start with an openjdk repo, and delete all the files as you added in the davlik code. Release it as GPL, and call it a derivative work. Not that I think they should have to do that just for the sake of implementing the API


>It wouldn't be that hard to start with an openjdk repo, and delete all the files as you added in the davlik code. Release it as GPL, and call it a derivative work.

They've done just that https://news.ycombinator.com/item?id=10803775


Taking sides of definitely a question of the lesser of two evils on this one.


I’m not sure if I have the timeline correct but I thought Java was owned by Sun Microsystems at the time when they made these decisions. I’m sure they rightly assumed Sun Microsystems would never do this. It is sad to see what Oracle is doing with Sun Microsystem’s creation.


It is sad. When I was young, about 16-19, I had a friend who worked for Sun Microsystems and he was an amazing mentor, and maybe twice a year I got to meet some of his colleagues too. They embodied 'the hacker' spirit that I believe hacker news represents - long grey hair, very open minded, very friendly, and loved being passionate about tech discussions while keeping an open mind and a willingness to be wrong.

These people turned me into who I am today by showing me a form of non-vain, open, intellectual curiosity that I try and emulate - the persons age, race, gender, religion -- all irrelevant -- it was about the ideas. Though they would look down on you if you used the wrong editor (go vi!) but they would smile and show you the way.


I don’t mean to be overly negative, but I hope you recognize the irony in describing your image of a hacker as someone with long, grey hair, and proceeding to say that superficial traits like appearance don’t matter, only ideas.


I did notice that after submitting it, and made a mental note in correcting it in the future. It was more for comic effect / appeal to stereotype - but that failure is mine. I'm always learning :)


The following is the fun history:

- Java is created / owned by Sun.

- Sun was fearful of MS's EEE approach (embrace, extend, exterminate) where MS took a thing, built their own, pushed their own tooling, added their own proprietary instruction, boom windows lock-in. So Sun basically made their contract: Java is free but only if you DO NOT introduce any new instructions, and implement a 100% compatible VM, nothing added or removed.

- Sun was making _some_ money out of mobile.

- Google introduced this pre-compiled java stuff. It used Java but compiled into binary. Sun was kind of excited. Java everywhere. Even though it violated the terms sun put out, sun was happy to get more java out there.

- Google / Sun had a more or less truce.

- Oracle bought sun. Sun didn't have much business left as Linux was obliterating their Unix business.

- Oracle saw the primary income from Sun as a lawsuit against google. And licensing on every Android phone period.

And thus today.


And given the paltry sum of the Sun acquisition, this is the M&A miss-of-the-decade for Google's M&A group.


> Oracle saw the primary income from Sun as a lawsuit against google. And licensing on every Android phone period.

I think they see the Sun acquisition more as controlling the Cobol of the 21st century. Putting a stick in Google's eye is just icing on the cake.


It is sad that us developers -actors in the very resource they are fighting for (our mindshare)- do not get any say in this.

Java belongs in a Foundation.


Sun wasn't happy at all, see Gosling interviews.

They just didn't had enough money to sue and decided to make juice out of lemons.


It is beyond sad. Oracle bought Sun exclusively to sue Google for its use of Java in Android. (I know someone involved in the lawsuits.) We really need to fix our patent system on the software side.


We really need to fix our patent system on the software side.

While this might be true, it's worth noting that this is a copyright case and not a patent case.


Oracle tried really hard to also make it a patent case, but aslup threw that stuff out.


Oracle bought Sun exclusively to sue Google for its use of Java in Android.

I think MySQL had something to do with it too. Even if just to capture the mindshare of all the developers using it at the time.


Yeah, at the time they were also talking about being like Apple and being a software and hardware company...so the Sun hardware was part of it too.


If Google cared 1 second about Sun they would have bought it, after being a major contributor to its downfall.


Like school bullying, they assumed that they could get away with it, because Sun was out of money to sue them.

Here is the latest Gosling interview on the subject.

https://www.youtube.com/watch?v=ZYw3X4RZv6Y&feature=youtu.be...


Thanks for sharing this video! This has definitely widened my perspective.


This is what Oracle does with every acquisition. You wring as much revenue out of a product as possible and when you cant get anymore you toss it aside and go acquire another product/company. This is what will happen to Netsuite which was recently acquired.


Well, one could argue that, had Google paid for the license, Sun wouldn't have been bought by Oracle.


> they rightly assumed Sun Microsystems would never do this

Interestingly, the article includes a quote from a Sun Microsystems co-founder who agrees with Oracle's stance on this:

> Among Oracle’s supporters in the case is Sun co-founder Scott McNealy, who said Java was created to be a platform-neutral system where programmers could “write once, run anywhere.”

> Java “is the foundation upon which our digital world is built,” McNealy said in a filing with the court. “Google stole that foundation, used it to build Android, and destroyed Oracle’s market in the process.”


> Interestingly, the article includes a quote from a Sun Microsystems co-founder who agrees with Oracle's stance on this

And yet Sun's CEO previously took the stand in support of Google.


> Java “is the foundation upon which our digital world is built”

I think McNealy is taking rather too much credit for Java here. Yes, it's widely used. The foundation? The foundation? Hardly.


I'm worried if this is again going to pose serious problems in using open source stack and building profitable solutions. So, If I'm going to build something profitable using R and Tensorflow/Keras then someday I could be sued by the consortium or Microsoft that owns Revolution Analytics (that controls R) ?


R is GPL, so as long as you're complying with the GPL terms in your use of it or derivative works, you're fine. If you make your own API-compatible reimplementation of R that isn't covered under the GPL's permission grant, though, then you might have issues (this case will in part determine what kinds of issues).

Also, the copyrights for R are mainly held by the nonprofit R Foundation, not by Revolution Analytics: https://www.r-project.org/foundation/. An API case from R copyright holders would additionally be really messy because a huge portion of the APIs originate in Bell Labs S, which they don't own the copyright to. Though there might be some sleeper case where whoever now owns the original S copyright pops up and sues R users for having cloned S's API...


Just checked Wikipedia and Microsoft indeed owns RA which "own" R. Interesting.

On the other it's not about open source. If you're willing to license stuff in good faith you should be fine.


This is a big shame. If only Google had purchased Sun Microsystems all this wouldn't have happened.

Sun was fine with what Google was doing.

When Oracle purchased Sun, it gained the rights to Sun's intellectual property and decided that it had a case against Google.

http://www.zdnet.com/article/sun-ceo-explicitly-endorsed-jav...


Another reminder never to do business with Oracle.


Oracle (Sun) paid probably hundreds of engineers to invent and maintain Java. As James Gosling says https://www.youtube.com/watch?v=ZYw3X4RZv6Y&feature=youtu.be... they gave away a lot but charged big companies to pay the expenses. Google should have paid that freaking licensing fee


Oracle paid for ammo it thought it could sue Google for.


> The case was remanded to a federal court in California to determine how much the Alphabet Inc. unit should pay.

No Google is not going to pay billion dollars, not yet. Very clickbaity title.


Title is perfectly accurate imo.

The case originally had Oracle seeking 8.8b in damages. Oracle won the revival. Therefore Oracle won the revival of a billion dollar case.

The title does not state or imply that google will pay the full amount, only that the case is not dead.

I know, click bait is bad, but it really irks me that people on HN are so quick to pull the 'click-bait' card for no reason.

Would a different title really change anyone's interpretation of the article? I don't think so.


How is the title click-bait? It doesn't say that Google will pay billions. It says it is a billion-dollar case...and it is (at least potentially).

  If this meets your definition of "very clickbaity" then where could you go to avoid click-bait?!


Well it's 25% clickbaity IMO - it was the billion dollar case, but perhaps "Java Copyright Case" would have been better.


OT: Thinking about API copyright I wonder how that is supposed to work in other programming languages e.g. Golang. Lets assume Google owns the copyright of the 'io.Writer' interface for the moment.

Is everybody who has implemented a struct with a Writer method which satisfies the 'io.Writer' interface and as oracle stated it 'who wants to use them for a competing platform or to embed them in an electronic device' now (hypothetical) at risk of being prosecuted because they infringe Googles copyright?

---

I am well aware that Google was the respondent in the Oracle vs. Google case.


Short answer: no

The law doesn't work as a set of naive rules like "If API->You need a license" because human life is full of nuances that can never be fully captured in a set of rigid rules. I know that people are uncomfortable with this truth, because our systems of courts often appears to the casual observer as just a bunch of "elders" making subjective decisions. Hence "smart contracts" etc.

And while the criticism isn't completely wrong, the system as it exists in the US today is actually working quite well, with the professional ethos and rules of the court system being somewhat successful at overriding any individual judge's predilections.

Anyway, in your case the difference is obviously one of scope. Even in the original ruling that affirmed APIs to be subject to copyright, the judge ultimately dismissed the case because they considered Google's actions to fall under "fair use".

While this was now struck down on appeal, it is absolutely certain that copying a single method's signature would still be protected as fair use. Moreover, in the case you mention, a method such as File.write() would probably not fall under any copyright because there isn't much of any creativity involved.


While I understand your point, your argument has very little foundation. You are basically saying: "Everything works very well and if a judge decides something you should respect that, as he has good reason to judge it his way".

One thing I have a particular problem with is that even judges from the same country seem to come to different results on the same case. I know its not unusual but that underlines my point that just because some judge came to some verdict, it isn't necessarily true.

And if 'the system as it exists in the US today is actually working quite well', why does a company like Google with a lot of smart people will have to pay a fine which probably will be as valuable as the whole Java platform? In a system that actually works well, the smart people would have seen what was going to happen and different judges would come to the same result.

And that something as 'simple' as a single method interface doesn't require any creativity is just wrong. I am sure there are a lot of famous creator quotes about that, the first I was able to find is from Steve Jobs:

  Simple can be harder than complex: You have to work hard to get your thinking clean to make it simple. But it’s worth it in the end because once you get there, you can move mountains. [1]
In the case of Golang that would translate to: It is much harder to build a universal single method interface for all kinds of write operations opposed to specific write methods for different use-cases.

[1]: https://www.goodreads.com/quotes/445279-simple-can-be-harder...


There's a difference between using an API and reimplementing one. Nobody's saying that you can get in copyright trouble for using an API. And to my knowledge, Go(lang) doesn't have the "embed in an electronic device" restriction that Java had.

If you tried to create a different implementation of Go that used the same API, whether you could get in trouble depends on Google's license. And then, if the license is against you, whether you do get in trouble would be at Google's discretion.

Note well: IANAL. Also, I'm still hoping that this "copyrighting the API" will be overturned at the Supreme Court, in which case this whole conversation is moot.


I agree it seems that way, but IMO JavaScript/v8 only exists (or is only the defacto client-side runtime) because Sun/Oracle messed up the Java/JVM trajectory at least twice.

1) was Sun making applets suck so bad, e.g. the JVM itself was too slow pre-JIT, classloading over the wire sucked, DOM interaction was hard (AFAIU/IIRC), etc.

I don't think any of these problems were fundamental to "put a VM in the browser", as conceptually Java & JS VMs aren't that different: the trade-offs JS/Brendan picked just worked better.

2) was Oracle being so lawsuit happy, as I think Dart could have been "just a faster/better browser-based JVM" (basically applets done right/with a great pre-JIT JVM) and not the combined "new language + new VM + new ecosystem", had Google felt comfortable using the Java language. It would have made a ton of sense, to reuse all their existing/internal Java tooling/knowledge/etc. But not with Oracle already breathing down their neck re Android.

Anyway, agreed it doesn't seem that way, but I think v8's success is actually more related to Sun/Oracle/Java's mistakes/missed opportunities than is initially apparent.

Not complaining, as we're in a great place now with v8/TypeScript/React Native being basically "the VM + type-safe language + framework that Java could have been", but with legitimately awesome features e.g. TS's type system, RN hot loading, etc.


I admit i don’t understand the details of that case fully and have no time to waste to change that... What i can say: To me it seems like oracle only bought Sun to squeeze out money from it’s “intellectual property” as hard as possible, giving a shit for all the(not fully finished) work Sun did in the years before to make Java a good Open Source citizen that could easily delivered in Linux distributions. The very first thing oracle did was making that harder again and limiting access to the compatibility test suite. Oracle is a greedy company that doesn’t care about anything than making more money, no matter what it costs and no respect to any otger party in no way. They give not the slightest F about being a good OpenSource citizen, in no area where they enter that ecosystem. And their products might have some nice features sometimes but in the end are hard to handle/install/maintain expensive crap. I didn’t write a 100 lines of Java since they own it, and i try to avoid it wherever i can find a viable alternative.


This is ridiculous. Google won two jury trials and the CAFC has no business deciding copyright cases.


I honestly don't know if a jury is the right place to decide a copyright case. Essentially, we take an extremely complicated chunk of law, take twelve random people and explain the basics of it... and then ask them to decide on a super complicated edge case of it. Does this work well?

I would argue Google is likely to win a jury case over Oracle in most cases because Google, at least until very recently, has widely been viewed as a "good" company, and is one that is popular with the average user.


>>Google won two jury trials and the CAFC has no business deciding copyright cases.

I think that's their only business, by design. https://en.wikipedia.org/wiki/United_States_Court_of_Appeals...


The CAFC is the appeals court for patents, which are not the same as copyrights. The local circuits handle copyright cases, except when there are also patent-related claims in the case.

So if you are a plaintiff in a copyright lawsuit and you want your appeals to get the pro-IP biased treatment from the CAFC instead of going to the local circuit, make sure to find a way to include a patent claim in your suit.


It's a patent court, not copyrights.


I suppose we could try lobbying Congress to change the copyright law to make an explicit provision for the fair use of software APIs.

Hey! Stop laughing!


The worst decision Google ever made (2011)

http://www.zdnet.com/article/the-worst-decision-google-ever-...


I bet Larry and Sergey are thinking we should have bought SUN.


Why? At worst Google will pay a couple billion for losing API suit. Oracle's patent suit already went down the tube. And by the time Oracle wins Java will be even less relevant for both Google and Oracle. Considering Oracle's Java business is sinking. They already threw away JavaEE to Eclipse and Cloud infra is heading Go way.

So instead of being hobbled by Sun JDK design decisions they worked on Dalvik and Java like paraphernalia. And big success of Android is partially due to that.


Patents/IP rights. Very strong team of eng. a lot of cool tech.


and Sun's campus is now prob worth most of the original sales price.


that would've been pretty cool. they had that kind of capital back then, right?


I think market cap of Google was close to 200B the deal was valued something like 7.5.


The actual opinion (just posted, had checked a few minutes ago and it wasn't available yet): http://www.cafc.uscourts.gov/sites/default/files/opinions-or...


So, for those like me who don't quite understand all the legalese: I've been operating under the belief that APIs and protocol "structures" were ruled as "non-copyright-able" before, while "implementations" absolutely were copyright-able. Was I wrong then, or am I wrong now?


They were considered non-copyrightable before. Then, in a surprise to many, they were ruled copyrightable in this case.

So far, the ruling only applies in the Federal Circuit. And you only get into the Federal Circuit when there is a patent aspect to the case. But a forum-shopping litigant could have a patent claim to the case, drop it part way through, and still wind up in the Federal Circuit on appeal (which, if I understand correctly, is exactly what happened in this case).


Same situation here. What changed since last trial? Wasn't Oracle demand based on software patents?

I'm confused...


Perhaps this is a naive question - but amongst the hundreds of of things Google has invented or has patents on, isn't there something they can find that Oracle has trampled on, and then use it as a negotiation tactic for making this all go away? e.g., If an API can be copyrighted, can a container registry interface also be copyrighted?

I agree, this is all stupid, but i'm asking this from the perspective of just finding examples to allow all parties to back off.


Settling out of court at this point would not be a good result, since the most important thing that will come out of this is the legal precedent.


Is that article two paragraphs long without source or attribution or am I doing the web wrong?


I used to keep a couple of 9-track tapes (see [1]) of the code I had written. Too bad I don’t have them anymore, I probably had some 50 year old API I came up with that someone somewhere violated.

If that seems absurd, consider how few people were programming back then and how fundamental and basic the APIs were. It’s worse than the patent mess. At least patents expire in 20 years! Copyright for those 1970s APIs will belong to my heirs for 50 years after I die! (see the Mickey Mouse law [2]).

[1] https://en.m.wikipedia.org/wiki/9_track_tape

[2] https://www.google.com/search?q=mickey+mouse+copyright+law&i...


Its really interesting how Microsoft changed their JVM into .net, with a nearly identical library API but so slightly different (often Upper case methods instead of lower case).

Would be an interesting idea if Google could compile JVM bytecode apps to run on .net VM. Of course JSV8 engine would be better, but is more difficult.



Yes looks great. Blog post is 6 years old though, is it still valid?


I always wondered why Google didn't buy Sun when they had the chance?

This (Android's use of Java) has always been a risk for Google. Either in form of the lawsuit but in more general what Oracle (or someone else) would do with Java.

Anyways. I hope both companies are smart enough to settle this in a reasonable manner.


They thought they could get away with it.


I just read the sub-thread from https://news.ycombinator.com/item?id=16691774 onwards and started nodding in agreement at the fine arguments therein. But then sanity hit me in the face like a damp glacier and I remembered the 9 lines of code in question.

Please anyone who's ever programmed anything; take a step back and tell me this is sane. Tell me there's not a billion cases like this out there waiting for a lawyer to unearth them.

However persuasive the step by step logic seems, it's the same step by step that paves the road to hell. If logic, reason and law bring us to this point then it's logic, reason and law that need to be carefully reexamined.


Sorry to be the bearer of bad news, but there are a rough Fermi-number million or more, of this kind of event, and this decision, which most people in the practice of writing software would consider a massive reversal, quite aside from being a retrograde step, implies that both sides of the deal are now in some sense duty-bound to investigate.

You could be the unwitting, unintending offendor by trivial API copying, entirely normal in your prior working experiences.

You could now be the person who has to inform senior staff that due to this decision, code your company owns as IPR is the subject of this kind of copying.

Think about it: If you discovered that any activity you did was now potentially valuable in a lawsuit to generate income, by what right do you not inform senior staff? What you feel about the lawsuit is distinct from your obligation as a company officer, regarding its status surely?


Can IBM enforce API copyright against BIOS vendors under this doctrine?

Does this revive the SCO linux case? Who owns the copyright for POSIX/UNIX system APIs?

What about cloud provider compatibility shims, e.g.: S3 reimplementations or Localstack?

I am left with nothing but more questions about the broadness of this decision.


I just hope we don't get to the place where basic function names are copyrighted, like add, insert, delete, remove, push, pop, sort, map, filter, foldl, foldr. I hope library writers don't have to pull out a thesaurus.


How about we stop using Java. It's a terrible language anyways.


I hate the whole api copyright stuff, but part if me is hoping this leads to a decline in popularity of Java.

I don’t even hate Java that much I just hate the Java is the only “serious programming language” attitude so common in this industry.


For programming phones, what language do you like better?


Swift is nice.


It's the world's number 1 langauge by many standards.


> Part of Google’s defense focused on the idea that Java was developed for desktop computers, while Android was created for phones and other mobile devices.

Is this really the best defense? The tag line is "write once, run anywhere" after all. I remember back in my CS days (mid/late 90s) when Java was first being pushed at my uni, the overly-enthusiastic vibe even back then was that Java would eventually be found everywhere, even in mundane devices like toasters and coffee machines.


True, but the version of Java for phones was J2ME, which was different from J2SE. Android implemented the API of the latter.


Sun was in the process of using J2SE, based on the assets they bought from SavaJE, which incidentally had an architecture quite similar to the first Android versions.


Was the TCK changed to allow for that?


No idea.


> There is nothing fair about taking a copyrighted work verbatim and using it for the same purpose and function as the original in a competing platform

Someone should appeal and bust their case that claims that APIs are copyrightable. And don't forget those who supported this crookedness - Microsoft.


With Oracle slapping patent infringements left and right for Java APIs, I predict in the next decade JAVA will sort of become irrelevant. I hope more universities are taking note of this and not teaching JAVA to first year students.

I also hope Oracle burns to ground in a decade.


If Google gives up Java for Android now, Java will drop out of top-5 languages in 5 years.


So does IBM now have an enforceable copyright on SQL that Oracle infringed upon?


People keep bringing SQL up, yet don't realize that SQL is an international standard which one needs to pay ISO for, and also to pay for certifications.

Oracle has payed for SQL. Google has not payed for Java.


The first SQL ISO standard is from 1987. Oracle's first commercial SQL DBMS came out eight years earlier in 1979.

In 1987, Oracle was already the largest database vendor and IBM's database business never recovered from that setback.

That said, I don't know if Oracle had some sort of licensing agreement with IBM during those early years. The question is what any such agreement would have looked like in light of the recent legal opinions on copyright.


Contrary to FOSS myths, SQL ISO standards aren't free and don't write by themselves, Oracle had a seat at the table just like everyone else that matters on the RDMS space.

IBM is doing pretty fine with DB 2 and Informix.


The problem for ORACLE is that if they win, they will have a Pyrrhic victory. The old adage of "Be careful what you wish for, you may actually get it" applies here.

Greed has consequences and greed will be the undoing.


What is the point of a copyright or patent trial if the biased Federal Circuit can just overturn the jury verdict? It's an straightforward violation of the 7th amendment.


Is this going to the Supreme Court or is this the final decision?


It's been sent back to the lower court to determine damages. After that Google can appeal to the Supreme Court if they can find some grounds on which to do so, and then the Supreme Court will decide whether to hear it or not.


If I recall correctly, the Supreme Court declined to hear an appeal of the API copyright question until Google had lost on fair use. Well, Google has now lost on fair use. The Supreme Court may be willing to take the case now (that is, before going back to the lower court to determine damages).


Will this have any reprocussions for AWS drop-in replacements?


Will this push Google to move towards dart lang even more now?


Wouldn’t Kotlin be the more logical route?


Doubt it if they still want the JVM. Sure Java the language is gone, but Kotlin on the JVM relies on the very non-Oracle-approved Java stdlib implementations that are at the root of this suit. If you want to argue Kotlin Native + NDK, sure, but it is very young (though I like it and have used it myself).


Today, Google is using the Oracle-approved form. They already switched Android from Harmony to OpenJDK in a previous release.

Since then, this suit has been about (a) deciding whether Google is guilty of wrongdoing in the past, and (b) what the extent of the damages should be for that historical wrongdoing should be, if any.

The outcome here doesn't really have any impact on the future of Android (except if Google wanted to factor the suit into their decisionmaking for their own reasons).


> The outcome here doesn't really have any impact on the future of Android

While most of your point is true, I disagree with this part. Using lawyers to tackle companies that succeed with only parts of your technology may send a chilling effect towards future uses. Also, knowing that you are not allowed to partake certain independent directions in the stack you choose for your devices is a legitimate reason to fear the continued use of that stack. Some are OK to them (e.g. conforming to the GPL on Linux) and some may not be (e.g. not being able to write portions of the stdlib without dealing w/ OpenJDK stewardship). I don't think these are their own reasons as much as they would be the reasons used by anyone who fears technologies stewarded by litigious outfits.


So you cut my comment off right at the part where I've pre-emptively addressed your entire criticism, and then you write out a paragraph detailing this criticism anyway because your position is contained squarely within the very part of my comment that you chose to leave out?


> (except if Google wanted to factor the suit into their decisionmaking for their own reasons)

> I don't think these are their own reasons as much as they would be the reasons used by anyone who fears technologies stewarded by litigious outfits.


You don't get to define "for their own reasons" to mean something else just so that you have a something to argue about. Doing something for one's "own reasons" means that the decision is theirs to make, in contrast to being legally compelled to act in a certain way. It doesn't mean acting in a way that nobody else would, nor acting in a way that nobody else would agree with.


Ah, I took "doesn't really have any impact" as "doesn't really have any practical impact" instead of "doesn't have any legal impact". I thought you were making a point about it being Google's personal reasons they might justify moving on as opposed to reasonable ones based on precedence of the decision.


But isnt that based on Java again?


No? It runs on the JVM and Kotlin/JVM links the Java standard library as part of its class path and compiler emits JVM bytecode, but that's not the issue here. I feel like people do not understand what this lawsuit is about. There's also a lot of technical people here reading the decision and making tech-minded assumptions about the business strategy. A far simpler solution than reconstructing the entire ecosystem would be to just switch off Dalvik VM and use the JVM.

The problem has nothing to do with using the Java API. It has everything to do with copying the OracleJDK API and implementation then building a secondary non-compliant JVM to run it. The OracleJDK (which is different from the OpenJDK) is not licensed in a way that allows copying.

I recommend folks read https://law.stackexchange.com/questions/8213/is-it-legal-to-... for a little background.

In short Google fucked up big time.


>The problem has nothing to do with using the Java API. It has everything to do with copying the OracleJDK API and implementation then building a secondary non-compliant JVM to run it. The OracleJDK (which is different from the OpenJDK) is not licensed in a way that allows copying.

Um, no. The case has solely to do with the copyright of the SSO of 37 Java API's that Google used. This has nothing to do with their VM.

>In short Google fucked up big time.

On the contrary, the CAFC fucked up big time for allowing API interfaces to be copyrighted.


You read one part of a sentence and then ignored the other part.

"It has everything to do with copying the OracleJDK API and implementation"


Actually, both parts were incorrect. This has nothing to do with implementation whatsoever. This copyright case is based solely on the SSO of 37 Java API interfaces and nothing else.


I am not a lawyer, but I wonder if Google could counter sue Oracle on the basis that that Java now implements some methods originally introduced in Google Guava?


What if this ends up true. Can Google just prefix all namespaces with google. ?

So now the API names are all changed.

Basically, if API are copyrightable, whats the minimal change to not consider it a copy?

com.oracle.String/lowerCase

Could this become

com.google.String/lowerCase

So now the name is changed? Or does this all now becomes a case of any similarity can be sued and on a case by case basis courts will jusge if its too similar or not enough?


IMHO, Google has stolen a very tiny piece of Java that Google thought to be free (some judges agreed with this opinion). At the time of Sun, $100M was really excessive. I think this case should be the opportunity to fix a very very small punishment so that companies stop these frivolous litigations.


I wonder if the meaning of this ruling will leak to other areas. For example, is “boilerplate” in contracts and other legal documents copyrightable? Who owns them? The lawyers, the law firms, the clients? Will attorneys pay other attorneys to use the same phrases and paragraphs?


I've read all the ideas around why or why not Google is liable or Oracle is being frivolous... Can an "Expert" tell me what would happen to Google(and Android by Association) if Oracle won full out? Besides the paying out of billion(s).


I propose a compromise: fine Google billions of dollars, but it goes to the taxman, not Oracle


Could Oracle be sued on the usage of SQL with it's products ? Or did they paid something to Ibm to use it ?


So what now? An appeal of the appeal?

This is the legal drama that never stops giving...


There are two next steps. One step is a retrial in the lower court, with fair use no longer a defense. The other is an appeal to the Supreme Court on whether an API can in fact be copyrighted.

If the Supreme Court appeal happens, it probably puts the lower court trial on hold. If Google wins the appeal, then (I think) there's no case left to try in the lower court.


Non-lawyer: is it over, as in Oracle won and judge must decide only the payment? Wiki says that Federal Circuit is the final for these things (I guess SCOTUS might review it...)


What other law stuff is Oracle going to test now? They already know they can clone AWS/GCE API with no repercussions.


Federal circuit decides to not properly apply ninth circuit law again, news at 11.


What's next? SCO winning an appeal? Sheesh.


It is time. #deleteoracle


[flagged]


Yeah, “stealing” an API and open source, building a successful mobile UI platform (unlike personal/embedded java and Sun’s own failed attempts at fragmentation) and contributing it free back to open source where it has been used as a base OS for thousands of new products from TVs to drones.


Please don't use the expression "contributing back" on a platform that Google rules with an iron fist. Not only is their draconian licensing contract kept secret, for fear that consumers might realize the sort of behavior Google is up to, but now Google is explicitly implementing block screens for installing the app store on an Android device that isn't adequately under Google's thumb. This isn't the behavior of a company who is "contributing back", it is the behavior of a company doubling down on controlling the industry.

https://arstechnica.com/gadgets/2018/03/google-starts-blocki...

The court didn't buy that Android was a gift to society worthy of fair use protection, and at this point, neither will anyone else.


All irrelevant. If I check out an open source project, expand it significantly, fix tons of bugs, increase performance, and commit the changes upstream, I have contributed back. The fact that I have built another product on top of that isn't 100% open source does not nullify the huge contributions of the former.

Chrome isn't open source. Chromium is. Chromium contains V8. V8 alone launched the huge nodejs community. In your mind, because Chrome isn't 100% open source, the fact that you can use pieces of it that are for tremendous benefit to the community doesn't count?

Handsets aren't the only thing Android is used for. Virtually every consumer product I see launch these days used some part of Android. TVs, smart speakers, IoT devices, thermostats, car entertainment systems, set top boxes, watches, and on and on. If someone wants to do a Kickstarter on a new piece of HW, the first thing that they're going to thing of is forking a chunk of AOSP, and to deny the immense value this has enabled for people building such devices is absurdly blind. Without ASOP, many of these projects wouldn't even exist.

Your positions are transparently hypocritical for someone who was a Windows Mobile fanboy, and rarely says a negative word about Apple or Microsoft's 100% proprietary platforms.


People in glass houses (or Google offices) should not throw stones. Also, I have a much longer history of criticizing Apple than Google, and give Microsoft significant flak on a regular basis for the way they've managed several aspects of Windows 10... including Mobile. I have no financial investment or implicit bias in any of these companies such as yourself.

I have no problem with proprietary software, I have a problem with proprietary software masquerading as open software and trying to use claims like "fair use" for something tightly controlled with secret arrangements and bullying the industry into compliance.

I would argue Android offers little benefit to the niches you detail, the only reason other Linux flavors don't make more sense is because they're taking advantage of the fact that they have to have Android developers anyways, because of app support. Android is not a good OS for smart devices, most of the bloat it shoves on top of Linux has little benefit to single-purpose hardware. I don't think Google gets to claim credit for the entire smart device market.


The proof is in the pudding. Prior to the introduction of Android, embedded Linux in consumer electronics was awful and many devices often selected Windows Embedded, QNX, etc. I worked on embedded Windows in automotive devices and know first hand how a) horrible it was (slow, buggy, insecure) and b) how horrible to Linux replacements were that tried to rig up a half functioning platform.

Most small companies do not have the skills to take vanilla Linux userspace, or even Debian or Ubuntu, and build out a polished mobile platform that they can shove into a thermostat or watch. The only semi-popular Linux attempts that succeeded in volume were HTML based like WebOS, which again, simply used a fork of an off the shelf complete platform mostly built by a corporation (e.g. WebKit)

You can argue all you want, but evidence suggests otherwise. Someone building a sealed, firmware for a device today that doesn't permit third party apps, still chooses AOSP as a base more often than not, and the reason they do so, is because there is huge value in the platform. Whether you like the design or not, whether you think it is bloated or not, people think that using AOSP to bootstrap their HW lowers their time to market or costs. And for those people, they are receiving value.


You mean the platform where one of only very, very few conditions on it's use was to make sure that your implementation was compatible with others?


The first smartphones had only 128mb of RAM and very slow performance. To remain compatible means supporting Swing, Java2D, CORBA, and a ton of other non-optional APIs included in the JDK. This was not really technically feasible in 2007.

For decades, people had been producing Java forks which weren't compatible, Sun didn't do much about them, and even encouraged them. Their main idea was to charge for the TCK and the right to use the Java(tm). Remember Ghost and WabaVM for PalmOS? Remember Kaffe +Classpath?

I'd argue that the idea of write-once-run-anywhere with a one-size-fits-all UI layer from mobile to server is a pretty bad idea. Apple seems to understand this, which is why iOS differs from NextSTEP.


Regardless, the CAFC has ruled -- twice -- that APIs are subject to copyright. The Supremes are likely to deny cert again, so that stands as the law of the land. You steal someone's API, you pay a penalty. Don't like it? Write your Congressman.


Law of the case, not law of the land.

This only stands as law of the land when the plaintiff manages to include a patent claim (even a weak one that later gets thrown out) to force the case under the Federal Circuit's jurisdiction, as happened here. They don't normally hear copyright cases.

While I'm sure more such patent claims will get bundled with API copyright claims in the future where a plaintiff can credibly manage that, it's not otherwise the law of the land.

(An aside: I think the Federal Circuit may have considered aspects of Ninth Circuit precedent in this ruling, as they're supposed to do for non-patent issues from the Ninth Circuit. Even they might rule differently in cases from other circuits, maybe just making it the law of cases they handle from the Ninth Circuit with significant persuasive impact on how they'd rule on cases from other circuits.)

Eventually a normal Ninth (or other) Circuit panel will rule on this. They're not bound by the CAFC ruling, though they will undoubtedly consider it. As soon as one circuit rules otherwise, that will create a circuit split.

Eventually, the Supreme Court will want to resolve that circuit split and will grant cert, either changing this bad precedent even for cases that go to the Federal Circuit or truly making it the law of the land.

A Supreme Court ruling on this would only affect the current Oracle v Google case if it happens before this case is fully finalized, given the doctrine of res judicata. But it would help future cases, including between these parties about a different topic, as well as between Oracle and other companies about the Java API.

With all of that said, contacting representatives in Congress and Senate to make explicit that APIs aren't copyrightable would still be great, as would narrowing the CAFC's jurisdictions to patent claims (and its otherwise specialized areas) or eliminating it entirely.


As I understand the CAFC to work, subject matter jurisdiction only applies to determining whether CAFC can rule on a case. Once they so rule, that ruling is precedent throughout the land -- irrespective of whether the topic of their ruling fell within their subject-matter jurisdiction.


> irrespective of whether the topic of their ruling fell within their subject-matter jurisdiction.

The opposite. Binding only within their subject-matter jurisdiction.

Which is good, because this ruling is so broad it's essentially trying to argue there's no such thing as fair use (because plagiarists arent protected by fair use, and all copyright infringers are plagiarists, and fair use is inherently copyright infringement, therefore...)


Do you oppose copyright on all software, i. e. source code, as well?

Because I could somewhat understand that sort of IP anarchism, although I wouldn't agree. But I'm having a hard time thinking about a coherent reasoning to see source code as copyrightable, yet deny the same to APIs.

Copyright applies to any creative endeavours that reach a certain level of breath and/or depth. Having been involved in a few library projects, I have witnessed quite a few where I would say the API was far more important, and sometimes took more work, than the underlying implementation.

Look, for example, at all the work done in standard-setting bodies: RFCs, WHATWG, etc. They are all licensed freely, yes. But the attachment of licenses to those documents implies an acknowledgement by the authors (and the community) that their work falls under copyright.


Yes, I (personally) oppose patent protection and copyright on software, and barring that, severe time limits, like say, 5 years. You really think an API should be protected from forking or reimplementation for A CENTURY? It's absurd, Oracle agrees with me (see link at bottom)

The entire PC industry was launched because clean room re-implementation of the API of the BIOS broke IBM's stranglehold. Is the world better without WINE? Without game or CPU emulators?

I am philosophically opposed to the idea of API copyrights especially. This is a corporate battle whose collateral damage is going to harm the entire industry.

It's funny how everyone loves forking, until tribalism kicks in, and then people start granting mulligans on philosophy just because of tribal positions on whichever company they don't like. Remember this? http://www.gordoni.com/software-patents/statements/oracle.st...

"Oracle Corporation opposes the patentability of software" "A balance of fifty years protection for direct copying of code would continue to be provided by copyright law."

Funny how perspective changes if you perform a buyout of a struggling company's assets to use it to shakedown the market.


We would be using Atari, Amiga and Macs instead, and maybe some UNIX variants as well.


I was a huge C64/Amiga fan, but I honestly don't think it would have been Atari or Amiga, both companies were horribly managed. And the Mac was just horrifically overpriced for what you got. At the same time Apple was shipping a $2k non-multitasking, B&W, 128k computer with shitty graphics and sound, Commodore was shipping the Amiga 1000, with twice the memory, and a custom chipset that was not equaled until years later by VGA, or to be honest, SVGA, and at half the price of the Mac 128k.

IMHO, the Amiga 1000 was the 'iPhone' of personal computers, ridiculously better than the Mac and PC at its launch date, it was a step-function better than the Mac. But Commodore was a bungling, mismanaged company that flushed a great opportunity down the drain. It's like if you invented the iPhone, but didn't know how to sell it, market it, and get product market fit.


Who knows, with the PC out of the way, even with their management mistakes, they might have survived.

And even if not, surely there would be another brand to gladly take their place.


Nostalgia: https://www.youtube.com/watch?v=q7rKj0DU8Xs sad this could be done in 1985.

Commodore was vertically integrated like Apple of today, they had a stellar custom chip development team, and had revolutionary chips in the worlds (AAA and Hombre) that would have been like 3dfx, but in 1992, delivering a quantum leap in gfx and single-texturing 3d pipeline well before others.

I'm really bummed the company flushed it down the toilet and "Xerox PARC"'ed itself, by having a winning team of researchers and engineers, but not being able to make a business.


>Do you oppose copyright on all software, i. e. source code, as well?

That has nothing to do with anything. Copyright is a human construct. Somethings are decided to be copyrightable and somethings are not. Not every creative endeavor should be copyrighted, other should, and other should with major limitations. APIs were never copyrightable. Ever. The computing and programming industry developed with this assumption - in fact, it may not have ever developed if that wasn't the case. Why does this need to change now? And not even through a new law but rather court re-interpretation.


My point is that there should be some criteria that determine if something should fall under copyright. And I'm having a hard time finding such a set that contains source code but does not include a (sufficiently extensive) API.

You're just asserting tradition. Yet you are not addressing my examples that directly show precedent within the industry for recognising copyright for APIs.


As I undestand it, there is a principle that legal contracts themselves cannot be copyrighted, despite the fact that they might well be the result of a considerable amount of creative work. The underlying principle here is that the legal effect itself cannot be subject to exclusive ownership, and the only way to get the same legal effect is to have the same contract.

I believe APIs can be considered under an analogous principle - that is, the ability to interoperate with a set of existing code shouldn't be subject to exclusive ownership, and you can't interoperate with the same existing code without implementing the same API, so APIs should not be copyrightable. (This draws a distinction between the API itself and the underlying implementation of that API).


Here is an example of an API subject to patents in MTC user equipment.

http://patents.2012.apievangelist.com/2017/12/07/2012-08-23-...


I said 'copyright'.


The "stolen IP" is the API definitions, nothing more.

    rtype foobar(type baz);
That's worth $8B to the appeals court, apparently.


I bet google wishes now they'd picked .NET for Android.


Why would Google want to use a language that is encumbered with patent promises and made by a company that has a history of shaking down Android OEM's?


Does oracle have a case or not? If you were Oracle, would you be ok not taking this to court?


In this field "having a case" depends not so much on objective truth but on subjective narrative, having enough money to pay more lawyers for a longer time than the opponent, finding the right judge, making sure the jury is stuffed according to plan and more of such skullduggery. If it were about objective facts the case would have been over and done with in a month with a definite conclusion, either it being OK to use API's without licensing or it being a violation to do so. If the outcome were the latter there would have been some bickering over how much to pay for said violation, add another month for that.

Alas, this is not about objective truth and "having a case". It is the result of a free but regulated market being infected by a parasitic organism which has turned the regulator's defence mechanisms to its own purpose, the which being the extraction of as much value as feasible while keeping the host alive.


The question here is not so much one of fact, but one of law. And stuffing the jury isn't an issue with the appeals court.


They clearly have a case because they just won it.


Yeah, seems a little strange to ask a question like that after the court already ruled in their favor. Whether you like it or not, clearly they did have a case.


Good. Initially, I thought the API decision was a bad one, but now I think the courts got it right.

If you've ever wrestled long with getting a program to compile, you realize it's non-trivial to wrap your brain around complex types. The API is a language and the compiler is a runtime producing output. I can design my API in something like Java and return null from all the methods while I do it. The compiler will still produce expected results when I try to string bits of it together.

For most languages, this work is hard, because everything is a runtime error from the compiler. There are elegant and inelegant ways to solve certain problems. The API determines that. It is itself a creative endeavor.

Google was given the opportunity to license the API. They still can under GPL, but that means complying with GPL, which they evidently did not want to do. Ruling in favor of fair use here creates a vague double standard. Business models like that of MongoDB, who releases their code under GPL for open source projects and charges a license fee for private projects, would become questionable. "Well, you give it away already, so it's fair use to use it any way we like without paying you!"


No. This decision upends decades of computing and programming culture for no discernible benefit to anyone (even Oracle).


Would you apply your reasoning to JavaScript, so that Safari and Chrome would be illegal due to failure to obtain a license for the JS APIs?

What about Linux? Linux copied the Unix syscall interface.

What about Wine?


There's the reverse of Wine now too with Microsoft's clean room (non-GPL2 and not currently open source at all) implementation of the Linux kernel kernel <-> userspace ABI.


> They still can under GPL, but that means complying with GPL, which they evidently did not want to do.

Not true. Android has been exactly that since 2016. Harmony is dead (killed at the ASF, even), and Android is now using OpenJDK.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: