Skip to content

Commit

Permalink
#1154 updates JMBE creator to work correctly with arm32 and aarch64 a…
Browse files Browse the repository at this point in the history
…rchitectures.
  • Loading branch information
Dennis Sheirer committed Mar 6, 2022
1 parent b2eb245 commit ec4f2ba
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 28 deletions.
19 changes: 13 additions & 6 deletions src/main/java/io/github/dsheirer/jmbe/JmbeCreator.java
Original file line number Diff line number Diff line change
Expand Up @@ -282,18 +282,25 @@ public static boolean isCorrectAsset(Asset asset, OSType osType)

switch(osType)
{
case LINUX_32:
case LINUX_AARCH_64:
return name.contains("linux") && name.contains("aarch64");
case LINUX_ARM_32:
return name.contains("linux") && name.contains("arm32");
case LINUX_X86_32:
return name.contains("linux") && name.contains("_32");
case LINUX_64:
case LINUX_X86_64:
return name.contains("linux") && name.contains("_64");
case OSX_64:
case OSX_AARCH_64:
return name.contains("osx") && name.contains("aarch64");
case OSX_X86_64:
return name.contains("osx") && name.contains("_64");
case WINDOWS_32:
case WINDOWS_AARCH_64:
return name.contains("windows") && name.contains("aarch64");
case WINDOWS_X86_32:
return name.contains("windows") && name.contains("_32");
case WINDOWS_64:
case WINDOWS_X86_64:
return name.contains("windows") && name.contains("_64");
case UNKNOWN:
case OSX_32:
default:
return false;
}
Expand Down
68 changes: 46 additions & 22 deletions src/main/java/io/github/dsheirer/util/OSType.java
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/*
* *****************************************************************************
* Copyright (C) 2014-2020 Dennis Sheirer
* Copyright (C) 2014-2022 Dennis Sheirer
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
Expand All @@ -24,16 +24,23 @@

public enum OSType
{
LINUX_32,
LINUX_64,
OSX_32,
OSX_64,
WINDOWS_32,
WINDOWS_64,
LINUX_X86_32,
LINUX_X86_64,
LINUX_ARM_32,
LINUX_AARCH_64,

OSX_AARCH_64,
OSX_X86_64,

WINDOWS_AARCH_64,
WINDOWS_X86_32,
WINDOWS_X86_64,

UNKNOWN;

public static EnumSet<OSType> WINDOWS_TYPES = EnumSet.of(WINDOWS_32, WINDOWS_64);
public static EnumSet<OSType> LINUX_TYPES = EnumSet.of(LINUX_32, LINUX_64, OSX_32, OSX_64);
public static EnumSet<OSType> LINUX_TYPES = EnumSet.of(LINUX_X86_32, LINUX_X86_64, LINUX_ARM_32, LINUX_AARCH_64);
public static EnumSet<OSType> OSX_TYPES = EnumSet.of(OSX_AARCH_64, OSX_X86_64);
public static EnumSet<OSType> WINDOWS_TYPES = EnumSet.of(WINDOWS_AARCH_64, WINDOWS_X86_32, WINDOWS_X86_64);

/**
* Indicates if this enumeration entry is a Windows type
Expand All @@ -51,6 +58,11 @@ public boolean isLinux()
return LINUX_TYPES.contains(this);
}

public boolean isOsx()
{
return OSX_TYPES.contains(this);
}

/**
* Detects the current host operating system and architecture
*/
Expand All @@ -61,37 +73,49 @@ public static OSType getCurrentOSType()

if(os.contains("win"))
{
if(arch.contains("64"))
if(arch.contains("x86") && arch.contains("64"))
{
return OSType.WINDOWS_64;
return OSType.WINDOWS_X86_64;
}
else
else if(arch.contains("x86") && arch.contains("32"))
{
return OSType.WINDOWS_32;
return OSType.WINDOWS_X86_32;
}
else if(arch.contains("aarch") && arch.contains("64"))
{
return OSType.WINDOWS_AARCH_64;
}
}

if(os.contains("mac") || os.contains("darwin"))
if(os.contains("mac") || os.contains("darwin") || os.contains("osx"))
{
if(arch.contains("64"))
if(arch.contains("x86") && arch.contains("64"))
{
return OSType.OSX_64;
return OSType.OSX_X86_64;
}
else
else if(arch.contains("aarch") && arch.contains("64"))
{
return OSType.OSX_32;
return OSType.OSX_AARCH_64;
}
}

if(os.contains("nux") || os.contains("nix") || os.contains("aix"))
{
if(arch.contains("64"))
if(arch.contains("x86") && arch.contains("64"))
{
return OSType.LINUX_X86_64;
}
else if(arch.contains("x86") && arch.contains("32"))
{
return OSType.LINUX_X86_32;
}
else if(arch.contains("aarch") && arch.contains("64"))
{
return OSType.LINUX_64;
return OSType.LINUX_AARCH_64;
}
else
else if(arch.contains("arm"))
{
return OSType.LINUX_32;
return OSType.LINUX_ARM_32;
}
}

Expand Down

0 comments on commit ec4f2ba

Please sign in to comment.