Unsaved Files Recovery Script
- 
 @guy038 Thank you for your response, and I appreciate your perspective on this. However, I feel like an important part of my message has been overlooked. I ended my last post with a very straightforward question: “I have a quick question, are any of you NPP decision-makers or developers? I ask this because I’m not familiar with the code and I would be interested in a more technical discussion regarding feasibility of what we are discussing.” This wasn’t rhetorical—I genuinely want to engage in a technical discussion about how we could implement safeguards without removing session persistence entirely. What continues to baffle me is that so much of this conversation has focused on criticism and personal philosophies about saving files rather than actual solutions. The most commonly proposed “fix” seems to be removing session persistence altogether, which—let’s be honest—feels like the easiest way to avoid the problem rather than solving it. Let’s take a step back: Users are consistently reporting data loss. That’s an undeniable fact. Instead of solving the problem, the response has been to dismiss these users as careless, lazy, or inexperienced. Eliminating persistence altogether punishes users who rely on it. That’s a bandaid, not a solution.I’d love to move this discussion forward into something constructive. If Notepad++’s current implementation of session persistence has flaws, let’s talk about ways to improve it rather than scrapping it entirely. For example: Could there be a built-in session recovery mechanism like many modern editors have? Could there be clearer warnings during updates if unsaved sessions exist? Could we implement a toggleable “safe mode” that reminds users to save periodically without disrupting workflow?If anyone here has actual insights into Notepad++’s codebase or development, I’d really like to hear about what is technically feasible. Let’s solve the problem—not just argue about it. 
- 
 @Private-Confidential said in Unsaved Files Recovery Script: “I have a quick question, are any of you NPP decision-makers or developers? I ask this because I’m not familiar with the code and I would be interested in a more technical discussion regarding feasibility of what we are discussing.” This wasn’t rhetorical We’ve got an entire FAQ entry on that. Go check out the first entry in our FAQ section. Specifically, regarding If anyone here has actual insights into Notepad++’s codebase or development, I’d really like to hear about what is technically feasible. There are those here who do have insights into the codebase, as some of the regulars have contributed codebase improvements. But no one here is a decision-maker for the codebase: Don is the one and only absolute decision maker, and he only comes to the Forum for announcements and the like, he does not read discussions like this one. 
- 
 🔹First off, I appreciate the time and effort you took to respond. I’m not here to engage in an argument, and I want to make it clear that I respect your perspective. However, I feel like there’s a fundamental disconnect in this discussion that I’d like to address. I understand and agree with a lot of what you said about personal responsibility and forming good habits. You’re right—discipline, structure, and accountability are key factors in both professional and personal success. But I think the core issue here isn’t about personal habits, it’s about software design and user experience. Let me explain why I think your response is missing the mark: 1️⃣ This isn’t about laziness—it’s about expectations.Users have been trained to trust that Notepad++ will restore their unsaved work, because that’s how the feature has always behaved. When an update wipes that work out without warning, it’s not just a bad habit issue—it’s a design failure. If a feature creates an expectation, the developers should either ensure it works reliably or warn users explicitly when it might fail. 2️⃣ Not everyone uses software the same way.I get that you’ve built habits that work for you. That’s great! But not everyone has the same workflow, use case, or cognitive processing style. Some users—myself included—rely on session persistence for reasons beyond convenience. That doesn’t make them reckless or foolish. It means they have a different way of working, and software should accommodate that when possible. 3️⃣ Blaming users doesn’t solve the problem.I keep seeing variations of the same argument: “Users should just save their files properly.” I don’t disagree that saving regularly is a good practice. But the fact that so many people continue to lose their work suggests that Notepad++ isn’t meeting user expectations in a reliable way. Telling users it’s “their own fault” doesn’t help them recover lost work, nor does it improve the software. 4️⃣ There are practical ways to fix this.Instead of debating philosophy, let’s talk solutions. A simple pre-update warning for unsaved sessions? A dedicated recovery mechanism? A more intuitive preferences UI that explains session management better? These are all things that could reduce frustration without removing useful features. I don’t expect everyone to agree with me, and I respect your viewpoint. But I hope we can shift this conversation away from user-blaming and toward actual solutions. Because at the end of the day, the goal is to make Notepad++ better and more reliable for everyone—not just those who already have strong backup habits. 
- 
 Addressing the Underestimation of Notepad++ UsersAlan, I find your response both amusing and concerning. You stated: “You over-estimate the abilities of the Notepad++ user that might be interested.” Let’s break that down for a moment. 1. A Curious ContradictionNotepad++ is a widely used text editor, heavily favored by developers, sysadmins, and power users. In fact, it’s often the go-to tool for those who appreciate lightweight, high-performance alternatives to bloated IDEs. To suggest that its users lack the ability to adapt a well-documented, step-by-step platform-agnostic script contradicts the very nature of the Notepad++ community. Are you implying that the same users who actively tweak config files, write macros, manage plugins, and even engage in scripting automation cannot follow basic adaptation instructions? That seems like a gross underestimation of the audience. 2. The Irony of Your ArgumentYour response essentially implies that: - Notepad++ users aren’t capable of following simple platform-specific instructions.
- Because of that, I shouldn’t have bothered providing a solution that requires even mild technical competency.
 Yet, in the same breath, you advocate for completely removing session persistence, which would force these same users to manually manage their file-saving process—a process that, as you argue, they should already know how to do. Do you see the inconsistency? 3. A Practical PerspectiveA well-documented script is not inherently complicated. Here’s why: - I have provided explicit instructions for adapting the script for Windows, Mac, and Linux.
- The necessary modifications involve changing a few file paths and substituting basic commands.
- For those who prefer a plug-and-play solution, porting to Python and packaging it as an executable is straightforward.
 Your assumption that Notepad++ users are incapable of adapting a recovery script suggests an unfortunate lack of faith in the community. It also ignores the reality that a vast number of Notepad++ users have the capability (or willingness) to follow clear instructions, especially when it helps prevent data loss. 4. Let’s Keep the Conversation ConstructiveI’m not here to engage in a battle of opinions without substance. I am, however, open to genuine discussions regarding feasibility, implementation, and practical improvements to both Notepad++ and this script. If you have constructive feedback on how to improve the approach—or, better yet, an alternative solution that doesn’t amount to removing a core feature and calling it a day—I’d love to hear it. Otherwise, dismissing the effort entirely based on an unfounded underestimation of Notepad++ users serves no purpose other than gatekeeping technical solutions. 5. Final ThoughtI’d argue that the true underestimation here is not of Notepad++ users’ capabilities, but rather the willingness to recognize and address a real problem with viable solutions. I look forward to your response. 
- 
 Thank you for pointing me toward the FAQ. I’ll take a look at that to better understand how decision-making around Notepad++ development actually works. That said, I do appreciate that some of you have contributed to the codebase, and I’d like to move the discussion in a more constructive direction. My intent was never to debate the merits of personal backup habits—though that discussion seems to have taken on a life of its own. Instead, my goal has been to explore what’s technically feasible in addressing a recurring user issue: unexpected data loss due to reliance on session persistence. I now understand that Don is the sole decision-maker and doesn’t actively engage in discussions like these. Given that, I’d like to ask those of you who do have experience with the Notepad++ codebase: - If this issue were to be addressed at the development level, what would be the biggest technical challenges in implementing a safeguard?
- Are there existing constraints within the codebase that make solutions like a pre-update warning, automatic session validation, or improved backup handling impractical?
- Have there been previous discussions or proposals around this, and if so, what were the outcomes?
 If the answer is that it’s just not a priority, that’s fine—I just want to understand the technical reasoning rather than continuing in circles about user habits. If there’s a more appropriate channel where technical feasibility is discussed (GitHub issues, a dev mailing list, etc.), I’d be happy to take the conversation there instead. Ultimately, I’d rather focus on what can be done rather than rehashing why it shouldn’t be done. Thanks in advance to anyone willing to engage in a more technical discussion. 
- 
 @Private-Confidential said in Unsaved Files Recovery Script: 1️⃣ This isn’t about laziness—it’s about expectations. Users have been trained to trust that Notepad++ will restore their unsaved work, because that’s how the feature has always behaved. When an update wipes that work out without warning, it’s not just a bad habit issue—it’s a design failure. If a feature creates an expectation, the developers should either ensure it works reliably or warn users explicitly when it might fail. I understand your points, but I fear you do not understand mine. This first statement of yours, is where the logic of your entire premise fails. They haven’t been trained, or else they would know that you need to backup unsaved work by saving it. This feature was never meant to be used in perpetuity for an unsaved document to be safe. That is the reality, and the weakness in your premise. Also where your premise dies, is in the ..If a feature creates an expectation...because the feature never created that expectation. The user not saving their work and they themselves depending on it, created that expectation. If I use a hammer to remove screws, they don’t come out. You can not demand a tool not designed for one job to work for another. The premise is ludicrous, and that’s what I’m getting at. If the user is not qualified to use the tool right, then the safest thing to do, is to take that tool away from that user, until they learn why the tool exists and how to use it properly.That’s why I pointed out that, your argument will have to evolve off of the prevent people from being lazy, forgetful (which the feature acutally helps) or complacent.It’s where the reason for your solution, or this discussion or need for the developers to get involved, loses any credibility. It is, in current parlance, ananny-statesolution to a problem that doesn’t truly exist. Rather it is created by a negligent behavior problem. You do not reward negligent behavior, to correct it. You allow the practicing negligent to continue until theyget it.Anyway, I believe you’ve been directed to the proper area for this discussion to continue to be entertained on github, in the development ecosystem where you can make your complaint, suggestions, and discussions flow…because as @PeterJones points out, this is not the place to argue your case for action. It’s a nice place for discussion, but hardly the place for actionable results. Good luck in your quest. 
- 
 @Private-Confidential - I believe the most common reason for “lost files” is that someone reinstalls or updates Notepad++ and then posts the horror story titled “my files are gone!” Another common cause seems to be people working in enterprise environments and their roaming desktop profiles get mangled. The enterprise issue is particularly challenging because people get randomly assigned virtual desktop sessions every they sign in. We can’t 100% depend on the contents of APPDATA, LOCALAPPDATA, or ProgramData being there tomorrow. Thus, while your script is laudable it likely will not work in many “my files are gone!” situations as the script makes the assumption that the currently installed copy of Notepad++ exactly matches how Notepad++ was installed and configured yesterday or some vague time ago. 
- 
 @Lycan-Thrope said in Unsaved Files Recovery Script: They haven’t been trained, or else they would know that you need to backup unsaved work by saving it. FWIW, I think you’ve misunderstood what @Private-Confidential meant by “trained” in this context: By enabling the unsaved files feature by default, many (most?) NP++ users have learned to expect unsaved work to be restored when NP++ is reopened, even when things like system restarts and software updates occur between NP++ sessions. Admittedly, many (most?) users were likely surprised by this dynamic because it goes against the logic of just about every other file-based software program ever created. In fact, one could even argue that many (most?) users discovered this dynamic accidentally because they weren’t expecting it at first. Either way, it’s a default feature that many (most?) NP++ users are at least aware of by now, whether they consciously make use of it or not. Furthermore, the fact that it’s an intentionally-designed feature makes it reasonable to accept the functionality as an expectation, even if it technically isn’t wise to rely on this expectation. That said, it’s also reasonable to accept that any issues with (or breakdowns in) this functionality are deficiencies that are at least worthy of investigation, even if the investigations aren’t a high priority. Obviously, if it is established that these deficiencies could be addressed somehow, the question of whether or not they should be addressed depends on a number of factors, including how many users actually want the issue addressed, the complexity of the resolution (for both end users and developers), etc. 
- 
 @mathlete2 said in Unsaved Files Recovery Script: FWIW, I think you’ve misunderstood what @Private-Confidential meant by “trained” in this context: By enabling the unsaved files feature by default, many (most?) NP++ users have learned to expect unsaved work to be restored when NP++ is reopened, even when things like system restarts and software updates occur between NP++ sessions. No @mathlete2 , I completely understand what he meant, and my response is still valid. No one trained those users, but themselves. The very nature, name and purpose of Sessiondoes not mislead anyone with any familiarity with the English language.The Session is a snapshot of the desktop before closing, it is not a backup option. If all files are properly saved, and a user closes and then reopens the program, their Session is exactly like they left it. Line and column locations of files, files that were open…etc. The ability of a document that is unsaved being retained in that Session snapshot is not it’s purpose, and no amount of logic by people that make themselves dependent on that as a feature can be justified in the overall continued reminder by all software (even NPP) to save your files/data before closing, changing, updating or reinstalling…etc. It is the stable traning mantra, if ever there were any training in this regard, to save data. So whether by accident or circumstance an unintended benefit of a feature, justifies someone ignoring the overriding mantra to save data/files. It is not a program’s job, as I’ve said, to save a user from themselves. It is the purview of deities. :-) 
- 
 @Lycan-Thrope said in Unsaved Files Recovery Script: So whether by accident or circumstance an unintended benefit of a feature, justifies someone ignoring the overriding mantra to save data/files. This should have been: 
 So whether by accident or circumstance, an unintended benefit of a feature, does not justify someone ignoring the overriding mantra to save data/files.
- 
 @Lycan-Thrope said in Unsaved Files Recovery Script: I completely understand what he meant, and my response is still valid That first part does not appear to be true: @Private-Confidential 's original comment began with “Users have been trained to trust that Notepad++ will restore their unsaved work”, and you responded with “They haven’t been trained”. The original comment was referring to the informal “training” that occurs as a result of observant usage of NP++ (and reading the online documentation). Such usage and reading teaches you that, in most cases, the default settings of NP++ will preserve the content within unsaved files. This “training”, while admittedly incomplete with respect to the overall functionality of the feature at hand, has undeniably occurred. Had you responded with something like “they haven’t been fully trained”, your claim would have been valid. However, as it stands, you either referred to a different type of training than what was originally implied, or incorrectly dismissed the training that has occurred. It’s also worth pointing out that this “training” provides users with correct information about how NP++ is designed to work (at least in most situations), and does not contradict the additional information you have provided. Specifically: your point that the session snapshot feature is not designed to function as a backup (which is valid) does not change the fact that users can reasonably expect their sessions to be restored in most situations, nor does it imply that improvements to this feature (or the implementation of additional features to support it) are unreasonable/unnecessary/useless/etc. The same can be said of your clarification that “No one trained those users, but themselves”: this is a true statement, but it doesn’t go against any of the points that @Private-Confidential is making. If anything, this observation highlights the point that they were trying to make with the original “training” comment: there is no formal training available for NP++ users, so their initial understanding will almost always be based on things like trial-and-error. Even users who go a step further and read the documentation won’t necessarily learn some of the key subtleties that you are pointing out; these subtleties are certainly consistent with the documentation, but they are not implied by the documentation - that in itself is a key subtlety that’s worth noting. TLDR: the main point that I was trying to make was that you are both raising valid points that do not necessarily contradict one another. At the very least, your ideas are not as incompatible with @Private-Confidential 's as you seem to think. 
- 
 @mathlete2 , 
 We’ll just have to agree to disagree. To state it plainly, no one trained those users to trust Notepad++ to do any such thing.They assumed, it would do it…and in perpetuity. That is immature and irresponsible behavior for someone to then need saving from themselves when any training ever given, or written for using programs always starts with the mantra to save one’s work. I was trying to be diplomatic about it using his own words, but your dissection has left me needing to state in plain language. The longer this discussion goes on, the more I think @Alan-Kilborn has a good point, to make the Session Backup not a default setting so people aren’t mistakenly trained( and assumes) the behavior is perpetually going to save them from themselves.
- 
 @Lycan-Thrope said in Unsaved Files Recovery Script: To state it plainly, no one trained those users to trust Notepad++ to do any such thing. We agree on that, but that’s not the point that @Private-Confidential and I are making; you don’t need someone to explicitly teach you something to be trained to do something. The training we are referring to is coming from standard usage of NP++: users are observing that, if they don’t explicitly close an unsaved file before closing NP++ itself, the content will be restored the next time NP++ is opened in the vast majority of situations (including system restarts and updates, and even NP++ updates). As you alluded to, this inadvertently lulls some users into a false sense of security; that’s the “training” we are referring to. Are these users a bit short-sighted for thinking this way? Perhaps. However, given how often it does work, it’s not difficult to understand why so many users over-estimate the effectiveness of this feature. @Lycan-Thrope said in Unsaved Files Recovery Script: I think @Alan-Kilborn has a good point, to make the Session Backup not a default setting so people aren’t mistakenly trained There is certainly some merit to this suggestion, but the developers would have to be careful with the implementation - you wouldn’t want users losing data when they update their NP++ installation. Even if the default is safely changed, that wouldn’t change the fact that the feature has room for improvement; if there’s a sensible way to mitigate data loss, isn’t it prudent to follow through on it? 
- 
 @mathlete2 said in Unsaved Files Recovery Script: The training we are referring to is coming from standard usage of NP++: users are observing that, if they don’t explicitly close an unsaved file before closing NP++ itself, the content will be restored the next time NP++ is opened in the vast majority of situations (including system restarts and updates, and even NP++ updates). As you alluded to, this inadvertently lulls some users into a false sense of security; that’s the “training” we are referring to. Are these users a bit short-sighted for thinking this way? Perhaps. However, given how often it does work, it’s not difficult to understand why so many users over-estimate the effectiveness of this feature. It does address it. No one, that makes their way here, can claim to be a computer neophyte. Period. If they have done any computer work previously, they will have learned the major rule. Save and save often. That NPP has an additional edge of protection, should not make them abandon their common sense computer behavior that should have been ingrained in them before they got here. This is my point. Because it’s suddenly fashionable to jump off a cliff, does that mean everyone should go jump off a cliff? Certainly not, so pardon me, if I don’t allow wiggle room to avoid the common sense solution, to the problem. Let them lose their data, until they get smart enough, not to. Can’t say it any more plainly. I don’t believe we should allow their assumptions (ass out of you and me) to rule the development direction, nor our concern over their bad habits. Callous, perhaps, but that is my experience to make certain that they get to learn the importance of the good habits, versus the bad. @mathlete2 said in Unsaved Files Recovery Script: There is certainly some merit to this suggestion, but the developers would have to be careful with the implementation - you wouldn’t want users losing data when they update their NP++ installation. Even if the default is safely changed, that wouldn’t change the fact that the feature has room for improvement; if there’s a sensible way to mitigate data loss, isn’t it prudent to follow through on it? My experience so far, is that past installations, do not change with updates, so that isn’t the issue. It’s the new installations, however, that don’t have the defaults set, which means they need to set things the way they’ll want them from that point, rather than get default actions that will teach them bad habits. Up to them to set the settings to do what they want, and now we get to the point that if they don’t know, they need to read. And I’ll repeat, that the sticking point that you, I and @Private-Confidential don’t seem to agree on, is that the prudent way to mitigate data loss, is to purposely save the document, originally and often. That is the part that their and your point in this discussion keeps discounting. The personal responsibility aspect. If this was my program that I’m developing and someone came to me with that argument, I’d advise them to find something else that fits their needs, as this program is obviously too advanced for their abilities…and move on. 
- 
 @Lycan-Thrope said in Unsaved Files Recovery Script: No one, that makes their way here, can claim to be a computer neophyte. Period. If they have done any computer work previously, they will have learned the major rule. Save and save often. That NPP has an additional edge of protection, should not make them abandon their common sense computer behavior that should have been ingrained in them before they got here. 
 Because it’s suddenly fashionable to jump off a cliff, does that mean everyone should go jump off a cliff? Certainly not
 (…)
 the prudent way to mitigate data loss, is to purposely save the document, originally and often.Once again, we agree on these points. However, they aren’t as relevant to the points we are making as you seem to think: I have already acknowledged that most NP++ likely discover the Session feature by accident, but perhaps I wasn’t clear about linking this discovery to the independent usage that I also mentioned. Personally, I discovered this feature as I was using NP++ on my own, and I’m guessing that this is true for most of the other users who make use of this feature as well. So, your “fashionable to jump off a cliff” argument isn’t likely relevant here (at least not for the majority of users). Either way, users who do make use of it learn that it is (surprisingly?) reliable - content is preserved in the vast majority of use cases. However, despite this high degree of reliability, I don’t think users are relying on it for important data, regardless of how they discovered it in the first place. Personally, I simply use it for things like scrap notes - content that isn’t important enough to warrant a new file in any of the various directories that I work out of, but important enough to be (potentially) useful again in the future, yet would not be significantly missed if lost. Obviously, I can’t speak for other users, but I’d imagine that they use this feature for the same sort of thing. Either way, I certainly agree that anyone who relies on it for more important content is doing so unwisely. In fact, this principle would still apply if the feature were to be reinforced: the goal of the proposed reinforcement is not, as you seem to fear (and rightfully so), to make users comfortable with expanding the importance of the content within their preserved files, it is simply to mitigate inconveniences. So, it’s not crucial to reinforce any limitations that this feature might have, but it is undeniably preferable. 
