Skip to content

Commit

Permalink
(peaceirisGH-608) Fix package url for hugo 0.102.0 and 0.103.0
Browse files Browse the repository at this point in the history
Prior to this change, the URL building for versions of hugo was
deterministic as the URLs for the packages were set to a
project-specific standard. That URL creation began to fail for macOS in
[0.102.0] and for Windows in [0.103.0]. It does not fail for Linux
because the hugo releases for Linux continue to include the old package
naming as an alias.

This change:

- Updates the `get-os` function to take the hugo version as additional
  input, altering the return value based on the version.
- Updates the `get-arch` function to take the operating system name and
  hugo version as additional input, altering the return value based on
  both. Including the OS name is required for handling macOS.
- Fixes peaceiris#608
- Fixes peaceiris#605
  • Loading branch information
michaeltlombardi committed Oct 6, 2022
1 parent a2eba60 commit aa30cbc
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 10 deletions.
27 changes: 23 additions & 4 deletions src/get-arch.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,30 @@
export default function getArch(arch: string): string {
export default function getArch(arch: string, os: string, version: string): string {
var segments = version.split('.').map(s => parseInt(s));

if (os == 'darwin' || (os == 'macOS' && segments[0] >= 0 && segments[1] >= 102)) {
return 'universal'
}

if (segments[0] >= 0 && segments[1] >= 103) {
switch (arch) {
case 'x64':
return 'amd64';
case 'arm64':
return 'arm64';
default:
throw new Error(`${arch} is not supported`);
}
}

switch (arch) {
case 'x64':
return '64bit';
return (segments[0] >= 0 && segments[1] >= 103) ? 'amd64' : '64bit';
case 'arm':
return 'ARM';
if (segments[0] >= 0 && segments[1] < 102) {
return 'ARM';
}
case 'arm64':
return 'ARM64';
return (segments[0] >= 0 && segments[1] >= 103) ? 'arm64' : 'ARM64';
default:
throw new Error(`${arch} is not supported`);
}
Expand Down
9 changes: 5 additions & 4 deletions src/get-os.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
export default function getOS(platform: string): string {
export default function getOS(platform: string, version: string): string {
var segments = version.split('.').map(s => parseInt(s));
switch (platform) {
case 'linux':
return 'Linux';
return (segments[0] >= 0 && segments[1] >= 103) ? 'linux' : 'Linux'
case 'darwin':
return 'macOS';
return (segments[0] >= 0 && segments[1] >= 102) ? 'darwin' : 'macOS'
case 'win32':
return 'Windows';
return (segments[0] >= 0 && segments[1] >= 103) ? 'windows' : 'Windows'
default:
throw new Error(`${platform} is not supported`);
}
Expand Down
4 changes: 2 additions & 2 deletions src/installer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,10 +47,10 @@ export async function installer(version: string): Promise<void> {
const extended: string = core.getInput('extended');
core.debug(`Hugo extended: ${extended}`);

const osName: string = getOS(process.platform);
const osName: string = getOS(process.platform, version);
core.debug(`Operating System: ${osName}`);

const archName: string = getArch(process.arch);
const archName: string = getArch(process.arch, osName, version);
core.debug(`Processor Architecture: ${archName}`);

const toolURL: string = getURL(osName, archName, extended, version);
Expand Down

0 comments on commit aa30cbc

Please sign in to comment.