Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ package_rename_config:
ios:
app_name: # (String) The display name of the ios app
bundle_name: # (String) The bundle name of the ios app
override_old_package: # (String) Use this to replace the old bundle identifier with the new bundle identifier
package_name: # (String) The product bundle identifier of the ios app

linux:
Expand Down
3 changes: 2 additions & 1 deletion example/example.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,13 @@ package_rename_config:
android:
app_name: Package Rename Demo
package_name: rocks.outdatedguy.packagerenamedemo
override_old_package: com.example.example
override_old_package: com.example.package_rename_example
lang: kotlin

ios:
app_name: Package Rename Demo
bundle_name: renamedemo
override_old_package: com.example.packageRenameExample
package_name: rocks.outdatedguy.packagerenamedemo

web:
Expand Down
1 change: 1 addition & 0 deletions example/package_rename_config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ package_rename_config:
ios:
app_name: Package Rename Demo
bundle_name: renamedemo
override_old_package: com.example.packageRenameExample
package_name: rocks.outdatedguy.packagerenamedemo

web:
Expand Down
4 changes: 2 additions & 2 deletions example/pubspec.lock
Original file line number Diff line number Diff line change
Expand Up @@ -134,10 +134,10 @@ packages:
dependency: transitive
description:
name: vector_math
sha256: d530bd74fea330e6e364cda7a85019c434070188383e1cd8d9777ee586914c5b
sha256: "80b3257d1492ce4d091729e3a67a60407d227c27241d6927be0130c98e741803"
url: "https://pub.dev"
source: hosted
version: "2.2.0"
version: "2.1.4"
yaml:
dependency: transitive
description:
Expand Down
37 changes: 21 additions & 16 deletions lib/platforms/ios.dart
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,10 @@ void _setIOSConfigurations(dynamic iosConfig) {

_setIOSDisplayName(iosConfigMap[_appNameKey]);
_setIOSBundleName(iosConfigMap[_bundleNameKey]);
_setIOSPackageName(iosConfigMap[_packageNameKey]);
_setIOSPackageName(
oldPackageName: iosConfigMap[_overrideOldPackageKey],
packageName: iosConfigMap[_packageNameKey],
);
} on _PackageRenameException catch (e) {
_logger
..e('${e.message}ERR Code: ${e.code}')
Expand Down Expand Up @@ -96,7 +99,10 @@ void _setIOSBundleName(dynamic bundleName) {
}
}

void _setIOSPackageName(dynamic packageName) {
void _setIOSPackageName({
dynamic oldPackageName,
dynamic packageName,
}) {
try {
if (packageName == null) return;
if (packageName is! String) throw _PackageRenameErrors.invalidPackageName;
Expand All @@ -111,26 +117,25 @@ void _setIOSPackageName(dynamic packageName) {
// Replaces old bundle id from
// `PRODUCT_BUNDLE_IDENTIFIER = {{BUNDLE_ID}};`
.replaceAll(
RegExp(
r'PRODUCT_BUNDLE_IDENTIFIER = ([A-Za-z0-9.-_]+)(?<!\.RunnerTests);',
),
'PRODUCT_BUNDLE_IDENTIFIER = $packageName;',
)
// Replaces old bundle id from
// `PRODUCT_BUNDLE_IDENTIFIER = {{BUNDLE_ID}}.RunnerTests;`
.replaceAll(
RegExp('PRODUCT_BUNDLE_IDENTIFIER = (.*?).RunnerTests;'),
'PRODUCT_BUNDLE_IDENTIFIER = $packageName.RunnerTests;',
)
RegExp(
'PRODUCT_BUNDLE_IDENTIFIER = $oldPackageName(?<!\\.RunnerTests);',
),
'PRODUCT_BUNDLE_IDENTIFIER = $packageName;',
)
// Removes old bundle id from
// `PRODUCT_BUNDLE_IDENTIFIER = "{{BUNDLE_ID}}.{{EXTENSION_NAME}}";`
.replaceAllMapped(
RegExp(
r'PRODUCT_BUNDLE_IDENTIFIER = "([A-Za-z0-9.-_]+)\.([A-Za-z0-9.-_]+)";',
'PRODUCT_BUNDLE_IDENTIFIER = $oldPackageName\\.([A-Za-z0-9.-_]+);',
),
(match) {
final extensionName = match.group(2);
return 'PRODUCT_BUNDLE_IDENTIFIER = "$packageName.$extensionName";';
final extensionName = match.group(1);
final isContains = packageName.contains(extensionName.toString());
if (isContains) {
return 'PRODUCT_BUNDLE_IDENTIFIER = $packageName;';
} else {
return 'PRODUCT_BUNDLE_IDENTIFIER = $packageName.$extensionName;';
}
},
);

Expand Down