iOS Build Environment Help Center

xcopy error : "Cannot perform a cycling copy"

append delete Antonio

During the execution of IoS Builder I am getting the error:
"Cannot perform a cycling copy" just after the line

+ Copying resources...

Reply RSS

Replies

append delete #1. Pierre-Marie Baty

Hello

Is it possible that the dialog box shown in this screenshot did not show up on your screen ?
https://ibb.co/b76chdc

This is baffling...

append delete #2. Antonio

• Windows 10 Enterprise Vers90n 21H1 build 19043.1415
• iOS Builder version 3.45
• iOS SDK version 14.5

I already wrote when it happens. I had a look to the script, and found the point where the xcopy command is called.
Do you require further information?
Thanks

append delete #3. Pierre-Marie Baty

Hello

This error happens when the target directory of the xcopy command is a children of the source directory. It means a copiable resource was mistakenly detected. It would be interesting to find out which one and why.

Do you have the possibility to share that Xcode project with me so that I reproduce the problem ? Confidentiality is guaranteed.

If not, you can try running the build script in debug mode by holding down the Shift key when you click the Build button. A lot more info will appear on screen, until the point where it fails. At this point you should have the full log in the build.log file in the Xcode project directory. It will indicate the source and target directories. Once you know them, you'll need to investigate where they come from - I'll help you do that.

append delete #4. Antonio

Hi,
it seems that in RES the script include also the "source" directory that is " D:\VirtuSimDev\BuildIoS\"

then when xcopy starts (line 2564) it fails
Here the from the log:

+ Copying resources...
Directory: D:\VirtuSimDev\BuildIoS\Data -> build\Release-iphoneos\iPhone-target\VenTrainer.app\Data
Directory: D:\VirtuSimDev\BuildIoS -> build\Release-iphoneos\iPhone-target\VenTrainer.app\BuildIoS

and the DUMP for RES
RES= "D:\VirtuSimDev\BuildIoS\Data" "LaunchScreen-iPhone.storyboard" "LaunchScreen-iPhonePortrait.png" "LaunchScreen-iPhoneLandscape.png" "LaunchScreen-iPad.storyboard" "LaunchScreen-iPad.png" "D:\VirtuSimDev\BuildIoS" *.png Data

How can I fix it?

append delete #5. Pierre-Marie Baty

Well, if it's included in the resources to copy, it means this path appears somewhere in your Xcode project file (Unity-iPhone.xcodeproj\project.pbxproj) in the PBXCopyBuildPhase section. I suspect a problem with the Xcode project file at this point, and I guess it would (or *should*) also fail to build on Mac.

FYI you can open that .pbxproj file with a text editor. If you can't make sense out of it, then send it to me and I'll try to pinpoint the problem.

append delete #6. Antonio

How can I send you the file?

append delete #7. Pierre-Marie Baty

Send it to my email address, pm @ this domain.

append delete #8. Pierre-Marie Baty

I could reproduce the problem. It seems that the localization files are the cause of the issue.

% project.pbxproj

/* Begin PBXResourcesBuildPhase section */
		1D60588D0D05DD3D006BFB54 /* Resources */ = {
			isa = PBXResourcesBuildPhase;
			buildActionMask = 2147483647;
			files = (
				9D9DE4EA221D84E60049D9A1 /* Data in Resources */,
				56C56C9817D6015200616839 /* Images.xcassets in Resources */,
				E2F74BB4BC90D6D0C95A7400 /* LaunchScreen-iPhone.storyboard in Resources */,
				4B9145F3AA81D792E104961B /* LaunchScreen-iPhonePortrait.png in Resources */,
				19B34F58891B4EF4D60DF47B /* LaunchScreen-iPhoneLandscape.png in Resources */,
				E5D44EB18CC968758D9231A7 /* LaunchScreen-iPad.storyboard in Resources */,
				66DF4ABE8ADB1F62E9B6DCF9 /* LaunchScreen-iPad.png in Resources */,
				B06E4FFBB4AF2AD5831382BF,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
%

I see that the last resource "B06E4FFBB4AF2AD5831382BF" has been added by something else than the Unity editor (because it has no comment next to it). When looking up further that ID, I see its file reference:

%
B06E4FFBB4AF2AD5831382BF = {isa = PBXBuildFile; fileRef = C60A4653A6C5D7BFF3FAD160 /* I2 Localization */; };
%

Which in turns resolves to a PBXVariantGroup

%
		C60A4653A6C5D7BFF3FAD160 /* I2 Localization */ = {
			isa = PBXVariantGroup;
			children = (
				0D1A4CAFAC841ADAE12B5572 /* Localizable.strings */,
				22CF47378B22A456B4EF11BD /* InfoPlist.strings */,
				EBFC4CB783A6601289BC0B5B /* Localizable.strings */,
				30D0474AA8540C5D5414171B /* InfoPlist.strings */,
				70EE4D588B3B50DC9FC61DDC /* Localizable.strings */,
				71994D45BE2775D7B0ECBAE3 /* InfoPlist.strings */,
				A21845CC9A3EF8930D007416 /* Localizable.strings */,
				2A9A44519F16A8A10860FE2F /* InfoPlist.strings */,
				A8DF4C10BDE81BF453C3DA73 /* Localizable.strings */,
				FA9A47BAB90D82B15DAAC400 /* InfoPlist.strings */,
				8AE1448CB4430D3C68A30098 /* Localizable.strings */,
				36E94AB1A9B3AD399D155FE6 /* InfoPlist.strings */,
			);
			name = "I2 Localization";
			sourceTree = "<group>";
		};
%

At this point I'm unsure if it's the Xcode project file that is malformed, or if it's a bug in my parser. That's a possibility but I'd like to make sure. Can this project be built without problems on macOS ?

append delete #9. Antonio

I see that the last resource "B06E4FFBB4AF2AD5831382BF" has been added by something else than the Unity editor (because it has no comment next to it). When looking up further that ID, I see its file reference:

Nothing is run than the Unity Editor. Could be an issue in your parser?

append delete #10. Pierre-Marie Baty

Possibly. But bogus Xcode projects do exist, too. Can you make the macOS test ?

append delete #11. Catalin

I'm having the same issue with this error: "Cannot perform a cycling copy" Repro info:

- I also have I2 localization enabled /* I2 Localization */
- I don't have this issue in version in version 3.44. ios SDK 14.4
- I can reproduce this issue on 3.46. ios SDK 15.4
- I could not reproduce this issue on 3.46 WITHOUT I2 localization in the project. so it seams its related to how that plugin adds its folders to xcode.
- The project compiles fine on osx.

append delete #12. Catalin

After more investigation it seams that the I2 Localization plugin ( https://assetstore.unity.com/packages/tools/localization/i2-localization-14884#description )
Has its own PBXProject() xcode project class.

it does the following:

var project = new PBXProject();
string projPath = PBXProject.GetPBXProjectPath(pathToBuiltProject);
..
..
..
project.RemoveLocalizationVariantGroup("I2 Localization");
..
..
project.AddLocalization(langProjectRoot + "/Localizable.strings", langProjectRoot + "/Localizable.strings", "I2 Localization");
..
project.WriteToFile(projPath);
i dont have access to the implementation of PBXProject() and please note im not on latest version of I2. I presume the parser issue might be related to the fact that this is a root directory in the xcode project.

Please let me know if you need any more info on this as I'm having issues upgrading to latest ios builder version to fix another issue related to linking AVPro in a build :)

Thank you for your hard work!

append delete #13. Catalin

I can confirm that removing the PBXVariantGroup from xcode "fixes" this issue. Something has changed in the parsing of iosbuildenv between 3.44 and 3.46 that breaks PBXVariantGroup parsing.

append delete #14. Pierre-Marie Baty

Thank you Catalin, this is very valuable information. So a regression is confirmed in pbxprojparse. I'm going to check the differences between the codebases at these two points.

:: @Pierre-Marie Baty added on 11 Apr ’22 · 14:06

I think I got it correctly this time. I'm testing my changes...

append delete #15. Pierre-Marie Baty

@Catalin, would you mind please trying these updated pbxprojparse.exe and build script, and tell me whether your app localization works correctly ? If they do, I'll push a corrective update.

https://www.pmbaty.com/iosbuildenv/build+pbxprojparse.zip

Thanks in advance for your feedback.

P.S. I have the feeling these PBXVariantGroups never really worked totally correctly in fact. I hope they will now.

append delete #16. Catalin

I can confirm the issue is fixed with this modification. I no longer get the "Cannot perform a cycling copy" error

Nice work @Pierre-Marie Baty

append delete #17. Pierre-Marie Baty

I had no doubt that the "cycling copy" error was fixed, as I could test it, but what I wanted to know is: does the *localization system* of your app work properly ? :)

append delete #18. Catalin

Localization works. but then again. it worked without adding that PBXVariantGroups. I cant really tell you what those folders do. Those folders are empty in my project. From what I remember it has something to do with submitting to appstore and enabling some localization options in the store front. I am not publishing my app using iosbuildenv so I cant really confirm that's the case.

For now everything seams to be working fine. If something comes up with the localization I will let you know in more detail.

append delete #19. Pierre-Marie Baty

Those folders contain the translations for all UIKit elements, including the app name. But since Unity doesn’t use UIKit, only the translated app name is relevant here.

I’ll publish the update very soon. Thank you

Reply

(Leave this as-is, it’s a trap!)

There is no need to “register”, just enter the same name + password of your choice every time.

Pro tip: Use markup to add links, quotes and more.

Moderators: Pierre-Marie Baty