diff --git a/resources/locales.json b/resources/locales.json
index a65cf53051445d2ed34d3286dfc5ae75850d3fbe..7cf9fa9b89083f7cddfa40d2f630953f2065c3d0 100644
--- a/resources/locales.json
+++ b/resources/locales.json
@@ -911,10 +911,6 @@
         "code": "en_US",
         "name": "English (United States)"
     },
-    {
-        "code": "en_US_POSIX",
-        "name": "English (United States, Computer)"
-    },
     {
         "code": "en_VC",
         "name": "English (St. Vincent & Grenadines)"
@@ -1399,6 +1395,10 @@
         "code": "ga",
         "name": "Irish"
     },
+    {
+        "code": "ga_GB",
+        "name": "Irish (United Kingdom)"
+    },
     {
         "code": "ga_IE",
         "name": "Irish (Ireland)"
diff --git a/resources/update-locales.php b/resources/update-locales.php
index d5addd0a9ae91e1b4e9b13e6e48b58435cbbf13e..50d848c76a6881c33d31269dcfd4615f4249127a 100755
--- a/resources/update-locales.php
+++ b/resources/update-locales.php
@@ -29,13 +29,21 @@ if (!extension_loaded('intl')) {
 	exit(1);
 }
 
-$locales = array_map(function (string $localeCode) {
+require '../3rdparty/autoload.php';
+
+$locales = array_map(static function (string $localeCode) {
 	return [
 		'code' => $localeCode,
 		'name' => Locale::getDisplayName($localeCode, 'en')
 	];
 }, ResourceBundle::getLocales(''));
 
+$locales = array_filter($locales, static function (array $locale) {
+	return is_array(Punic\Data::explodeLocale($locale['code']));
+});
+
+$locales = array_values($locales);
+
 if (file_put_contents(__DIR__ . '/locales.json', json_encode($locales, JSON_PRETTY_PRINT)) === false) {
 	echo 'Failed to update locales.json';
 	exit(1);