View Bug Details

IDProjectCategoryView StatusLast Update
0001277DCP-o-maticBugspublic2018-04-20 12:11
Reportercarl Assigned To 
PrioritynormalSeverityminorReproducibilityhave not tried
Status confirmedResolutionopen 
Target Version2.12.x 
Summary0001277: Can't open a project that's stored in a OneDrive folder
Description

create directories error boost::filesystem::create_directory: Cannot create a file when that file already exists.

::status(x).type() returns 9: I think that's FILE_ATTRIBUTE_REPARSE_POINT

https://msdn.microsoft.com/en-us/library/windows/desktop/gg258117(v=vs.85)

TagsNo tags attached.
Branch
Estimated weeks required
Estimated work requiredUnknown

Activities

Carsten

2018-04-19 02:35

manager   ~0002377

Maybe that happens because OneDrive is actively syncing the file while DCP-o-matic is writing/recreating it.

But looks like a OneDrive issue to me.

  • Carsten

Carsten

2018-04-19 02:42

manager   ~0002378

Maybe we find other OneDrive users to confirm this issue. I understand there are different OneDrive configurations and addons. Maybe this happens only in specific scenarios?

  • Carsten

carl

2018-04-19 11:29

administrator   ~0002379

Happens all the time for me. The contents of the OneDrive folder have special NTFS types that we aren't dealing with.

carl

2018-04-19 11:34

administrator   ~0002380

I think it's this bug: https://svn.boost.org/trac10/ticket/5649

Carsten

2018-04-19 12:16

manager   ~0002381

So, is there something we can do about it? Should DCP-o-matic deal with bugs in other apps/libs?

Does it really only happen with 'Make DCP'? In that case, we could add a hint if we detect the file path to contain 'onedrive' - or is that too simple a thought? We could also give that hint right away when the project is created in a onedrive path.

  • Carsten

carl

2018-04-19 12:20

administrator   ~0002382

I think we have to do something. You can't even open an old project if it's on OneDrive. Maybe patch boost for the Windows version, or maybe work around it in DoM.

Carsten

2018-04-19 13:10

manager   ~0002383

Of course I have no idea in how far boost is needed for file access other than standard file operations.

The trouble is that OneDrive is not just an exotic tool. It's MS, and some people may use it now to store all their files in it, not just a dedicated folder. Probably more and more in the future.

While personally I am too conservative to store large files like DCPs in my dropbox per default, I could understand that people with large cloud storage and fast internet connections would love the idea to create their DCPs at home and then find them at the cinema automatically. As far as I know, with an Office365 account, you are allowed to use 1TB of cloud storage...

So, yes, maybe, sooner or later, there needs to be a solution.

  • Carsten

Carsten

2018-04-19 15:20

manager   ~0002384

Last edited: 2018-04-19 20:13

oops. That Bug is 5-7 years old...does it really still exist? I learned that WIN10 introduced new NTFS attributes, explicitly for cloud storage (online, local, etc.). Maybe it's a WIN10 issue. I could test in WIN7. Which doesn't solve the problem. Maybe for the time being, catch the 'onedrive' string in paths and issue a warning immediately, even before doing something...Not elegant, but the error message they are getting now doesn't help either, so it's better to give them something they understand and can act upon. As we see on the mailinglist, it is not immediately evident to the average user that their OneDrive is the issue.

  • Carsten

carl

2018-04-19 22:43

administrator   ~0002385

boost 1.67.0 does not appear to fix it. Everything in a onedrive comes back with status().type == 9 (both files and directories).

carl

2018-04-19 23:15

administrator   ~0002387

https://github.com/arduino/arduino-builder/issues/254

carl

2018-04-20 00:01

administrator   ~0002388

https://go-review.googlesource.com/c/go/+/86556/5/src/os/types_windows.go#121

carl

2018-04-20 01:00

administrator   ~0002390

This looks really unpleasant. For some reason it only seems to have become a problem with fairly recent Windows 10 updates. The go compiler has a fix (which makes the Arduino software work) and I think a similar concept needs to be applied to boost.

Carsten

2018-04-20 01:57

manager   ~0002391

Last edited: 2018-04-20 01:58

I thinks that's what I was referring to - the WIN10 Creators Update introduced these new NTFS File attributes...

  • Carsten

Carsten

2018-04-20 12:11

manager   ~0002392

So - issue a warning with anything 'onedrive' in it, or...? If it comes up more often, also for other apps, maybe it will be fixed in boost at some time. Do you want to be the one who fixes it? I have no idea how complex it could be...

  • Carsten

Bug History

Date Modified Username Field Change
2018-04-19 01:57 carl New Bug
2018-04-19 02:35 Carsten Note Added: 0002377
2018-04-19 02:42 Carsten Note Added: 0002378
2018-04-19 11:29 carl Note Added: 0002379
2018-04-19 11:34 carl Note Added: 0002380
2018-04-19 12:16 Carsten Note Added: 0002381
2018-04-19 12:20 carl Note Added: 0002382
2018-04-19 13:10 Carsten Note Added: 0002383
2018-04-19 15:20 Carsten Note Added: 0002384
2018-04-19 15:27 Carsten Note Edited: 0002384
2018-04-19 20:13 Carsten Note Edited: 0002384
2018-04-19 21:05 carl Status new => confirmed
2018-04-19 21:05 carl Summary Can't open a project that's store in a OneDrive folder => Can't open a project that's stored in a OneDrive folder
2018-04-19 22:43 carl Note Added: 0002385
2018-04-19 23:15 carl Note Added: 0002387
2018-04-20 00:01 carl Note Added: 0002388
2018-04-20 01:00 carl Note Added: 0002390
2018-04-20 01:57 Carsten Note Added: 0002391
2018-04-20 01:58 Carsten Note Edited: 0002391
2018-04-20 12:11 Carsten Note Added: 0002392