// Script for generating Spark download links // No dependencies; pure javascript. releases = {}; function addRelease(version, releaseDate, packages, downloadable) { releases[version] = {released: releaseDate, packages: packages, downloadable: downloadable}; } var sources = {pretty: "Source Code [can build several Hadoop versions]", tag: "sources"}; var hadoopFree = {pretty: "Pre-build with user-provided Hadoop [can use with most Hadoop distributions]", tag: "without-hadoop"}; var hadoop1 = {pretty: "Pre-built for Hadoop 1.X", tag: "hadoop1"}; var cdh4 = {pretty: "Pre-built for CDH 4", tag: "cdh4"}; var hadoop2 = {pretty: "Pre-built for Hadoop 2.2", tag: "hadoop2"}; var hadoop2p3 = {pretty: "Pre-built for Hadoop 2.3", tag: "hadoop2.3"}; var hadoop2p4 = {pretty: "Pre-built for Hadoop 2.4 and later", tag: "hadoop2.4"}; var hadoop2p6 = {pretty: "Pre-built for Hadoop 2.6 and later", tag: "hadoop2.6"}; var mapr3 = {pretty: "Pre-built for MapR 3.X", tag: "mapr3"}; var mapr4 = {pretty: "Pre-built for MapR 4.X", tag: "mapr4"}; var sources = [sources]; // 0.7+ var packagesV1 = [hadoop1, cdh4]; // 0.8.1+ var packagesV2 = [hadoop2].concat(packagesV1); // 1.0.1+ var packagesV3 = [mapr3, mapr4].concat(packagesV2); // 1.1.0+ var packagesV4 = [hadoop2p4, hadoop2p3, mapr3, mapr4].concat(packagesV1); // 1.3.1+ var packagesV5 = [hadoop2p6].concat(packagesV4); // 1.4.0+ var packagesV6 = [hadoopFree, hadoop2p6, hadoop2p4, hadoop2p3].concat(packagesV1); addRelease("1.4.0", new Date("6/11/2015"), sources.concat(packagesV6), true); addRelease("1.3.1", new Date("4/17/2015"), sources.concat(packagesV5), true); addRelease("1.3.0", new Date("3/13/2015"), sources.concat(packagesV4), true); addRelease("1.2.2", new Date("4/17/2015"), sources.concat(packagesV4), true); addRelease("1.2.1", new Date("2/9/2015"), sources.concat(packagesV4), true); addRelease("1.2.0", new Date("12/18/2014"), sources.concat(packagesV4), true); addRelease("1.1.1", new Date("11/26/2014"), sources.concat(packagesV4), true); addRelease("1.1.0", new Date("9/11/2014"), sources.concat(packagesV4), true); addRelease("1.0.2", new Date("8/5/2014"), sources.concat(packagesV3), true); addRelease("1.0.1", new Date("7/11/2014"), sources.concat(packagesV3)); addRelease("1.0.0", new Date("5/30/2014"), sources.concat(packagesV2)); addRelease("0.9.2", new Date("7/23/2014"), sources.concat(packagesV2), true); addRelease("0.9.1", new Date("4/9/2014"), sources.concat(packagesV2)); addRelease("0.9.0-incubating", new Date("2/2/2014"), sources.concat(packagesV2)); addRelease("0.8.1-incubating", new Date("12/19/2013"), sources.concat(packagesV2), true); addRelease("0.8.0-incubating", new Date("9/25/2013"), sources.concat(packagesV1), true); addRelease("0.7.3", new Date("7/16/2013"), sources.concat(packagesV1), true); addRelease("0.7.2", new Date("2/6/2013"), sources.concat(packagesV1)); addRelease("0.7.0", new Date("2/27/2013"), sources); function append(el, contents) { el.innerHTML = el.innerHTML + contents; }; function empty(el) { el.innerHTML = ""; } function getSelectedValue(selectEl) { return selectEl.options[selectEl.selectedIndex].value; } function versionShort(version) { return version.replace(/-incubating/, ""); } function initDownloads() { var versionSelect = document.getElementById("sparkVersionSelect"); // Populate versions for (var version in releases) { var releaseDate = releases[version].released; var downloadable = releases[version].downloadable; if (!downloadable) { continue; } // Don't display incubation status here var title = versionShort(version) + " (" + releaseDate.toDateString().slice(4) + ")"; append(versionSelect, ""); } // Populate packages and (transitively) releases onVersionSelect(); } function initReleaseNotes() { var releaseNotes = document.getElementById("sparkReleaseNotes"); for (var version in releases) { var releaseDate = releases[version].released; var verShort = versionShort(version); var contents = "