Ignore files and folders from Dropbox sync

I use Dropbox religiously to make sure my data is always backed up. This extends to my Git repositories as well as they live inside the Dropbox folder—If my laptop is stolen, I don’t want to lose that unfinished code change I was working on just because I hadn’t committed and pushed it yet.

The problem is, Dropbox and Git don’t always play that well together, so here are a couple of problems and solutions I’ve adapted to over the years.

While the article focuses on the node_modules folder in your git repository, the same techniques can can be used for any file or folder that you keep inside Dropbox.

Bluesky
Threads
Twitter / X
Mastodon
Instagram

Node module erroring on install

As you add files to your project, Dropbox will begin syncing each one to the cloud almost immediately. However, while Dropbox is syncing a file, the operating system locks it so that it doesn’t get changed mid sync and cause corruption.

Most of the time this Is fine and you will never notice it, however, when npm is installing node modules (ie. Running npm i), npm is making lots of small changes to the related files very repeatedly, but irregularly, and so inevitably, Dropbox tries to pick up and sync those files too soon. This means when npm goes back to edit that file, it finds it locked, which creates errors in installing the modules.

I imagine most other programs are more forgiving than npm. I’m just speculating, but I imagine when they hit a locked file, they hold off for a few moments to see if it’s released. For whatever reason, npm seems to give up quickly and simply show an error and skip the module.

The solution

The easiest solution, and one I did for a very long time, is to simply pause Dropbox syncing before you run npm i or before you install an individual module. This prevents the file from locking and the npm installations will then not error due to Dropbox.

Pausing the dropbox sync.

node_modules syncing forever

The node_modules folder taking a long time to sync might be something you haven’t noticed much, or if you have, you’ve dismissed it as a necessary evil. It’s not though, and the long syncing is also the cause or the previous issue and others.

Because the node_modules folder generally consists of thousands of tiny text files, even though it might not have a large file size, Dropbox can take many hours to transfer it entirely—and Dropbox is never able to estimate the time properly either (sometimes saying 3 days left, and sometimes saying 5 minutes).

While these transfers happen, other files you want to sync can be slower than usual, and so can other internet traffic (And did I mention it can be many hours?)

Even though the files are small, I imagine that with each file Dropbox has to set some things up and check differences, etc. This would mean the admin work increases when there are lots of files compared to when there are just a few.

The solution

The solution to this problems is a little more complicated than the last, but it also solves the problem of Dropbox’s locking your node_modules folder.

The solve is to tell Dropbox to ignore the node_modules folder entirely.

Remember that everything inside node_modules is version controlled and installed by npm using your package-lock.json. So you can always just run npm i again if you find yourself on another computer trying to pick up where you left off.

At the time of writing this, Dropbox doesn’t expose an ability to ignore a file or folder in the context menu options or settings, so we need to jump to the command line.

Mac
Open a terminal and type one of the following commands.

// Set it to ignore:
xattr -w com.dropbox.ignored 1 <absolute-path-to-file-or-folder>

// Revert it to sync:
attr -r com.dropbox.ignored <absolute-path-to-file-or-folder>

Windows
Open PowerShell (command prompt doesn’t work), and type in one of the following lines.

// Set it to ignore:
Set-Content -Path <absolute-path-to-file-or-folder> -Stream com.dropbox.ignored -Value 1

// Revert it to sync:
Set-Content -Path <absolute-path-to-file-or-folder> -Stream com.dropbox.ignored -Value 0

The change might take a few moments to come into effect (about 10 seconds in my experience), but you should eventually see the icon on the folder indicate its new status.

Note that in the above code snippets, you don’t have to type in the path to the file manually, instead, simply delete the part that says <absolute-path-to-file-or-folder> (Including the arrow brackets), place the typing cursor at that spot and drag the relevant file or folder into the window. This should automatically give you the absolute path.

That’s it!

Now dropbox will ignore that folder when it sees it which means no more syncing issues!

Thanks…

I also dissect and speculate on design and development.
Digging into subtle details and implications, and exploring broad perspectives and potential paradigm shifts.
Check out my conceptual articles on Substack or find my latest below.


You can also find me on Threads, Bluesky, Mastodon, or X for more diverse posts about ongoing projects.

My latest articles

Staging XR scenes (Keep doing your crappy little drawings)

Some people create beautiful perspective illustrations to visualise and storyboard their virtual reality designs And it’s tempting to think you’re not a strong designer if you’re not doing that too…

Focal point blocking for XR media

Planning out a linear VR experience requires thinking about where the viewers attention might be. Thinking about the focal points…

Designing immersive experiences

In traditional cinema, TV, or even the more modern phone screen, there’s limited screen real-estate. But removing that limitation creates a design problem…

The future is not prompt engineered

Let’s not pretend the importance of prompt engineering is ubiquitous. The most prevalent power of generative AI is in the way it adapts to us, not the other way around…

The typography of dates, times, & filenames

A deep dive into carefully considered date formatting, line length and general typography attributes of filenames…

Loosening the Shackles of Rapid Authoring Tools

Rapid authoring tools like Articulate Storyline and Evolve Authoring make sharing projects possible across a team of non-programmers, but your design must often adapted to the limited range of possibilities the tool allows…

Author:

Date:

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.