summaryrefslogtreecommitdiff
path: root/fluid
diff options
context:
space:
mode:
authorMatthias Melcher <github@matthiasm.com>2025-11-29 17:21:40 +0100
committerMatthias Melcher <github@matthiasm.com>2025-11-29 17:21:47 +0100
commit8f55e0634cef08d61d08f41305005b1eb18498eb (patch)
tree1f49e8cca44d700099dfde2398f115760d79372e /fluid
parent349b818d3fd4f568160537616857b9ff7d68d3aa (diff)
Fluid: Fix crash when saving an empty project.
Diffstat (limited to 'fluid')
-rw-r--r--fluid/Fluid.cxx10
-rw-r--r--fluid/Project.cxx8
2 files changed, 14 insertions, 4 deletions
diff --git a/fluid/Fluid.cxx b/fluid/Fluid.cxx
index 160dabb5c..bfbd5902c 100644
--- a/fluid/Fluid.cxx
+++ b/fluid/Fluid.cxx
@@ -587,10 +587,12 @@ void Application::save_project_file(void *v) {
fnfc.options(Fl_Native_File_Chooser::NEW_FOLDER|Fl_Native_File_Chooser::SAVEAS_CONFIRM);
#endif
fnfc.filter("FLUID Files\t*.f[ld]");
- if (!proj.projectfile_path().empty())
- fnfc.directory(proj.projectfile_path().c_str());
- if (!proj.projectfile_name().empty())
- fnfc.preset_file(proj.projectfile_name().c_str());
+ if (proj.proj_filename) {
+ if (!proj.projectfile_path().empty())
+ fnfc.directory(proj.projectfile_path().c_str());
+ if (!proj.projectfile_name().empty())
+ fnfc.preset_file(proj.projectfile_name().c_str());
+ }
fnfc.filter("Fluid Project\t*.fl\nAny\t*");
if (fnfc.show() != 0) return;
c = fnfc.filename();
diff --git a/fluid/Project.cxx b/fluid/Project.cxx
index 750beccf1..e2599e3e6 100644
--- a/fluid/Project.cxx
+++ b/fluid/Project.cxx
@@ -73,6 +73,7 @@ void Project::update_settings_dialog() {
\return the path ending in '/'
*/
std::string Project::projectfile_path() const {
+ if (!proj_filename) return std::string{};
return end_with_slash(fl_filename_absolute_str(fl_filename_path_str(proj_filename), Fluid.launch_path()));
}
@@ -81,6 +82,7 @@ std::string Project::projectfile_path() const {
\return the file name without path
*/
std::string Project::projectfile_name() const {
+ if (!proj_filename) return std::string{};
return fl_filename_name(proj_filename);
}
@@ -103,8 +105,10 @@ std::string Project::codefile_path() const {
std::string Project::codefile_name() const {
std::string name = fl_filename_name_str(code_file_name);
if (name.empty()) {
+ if (!proj_filename) return std::string{};
return fl_filename_setext_str(fl_filename_name(proj_filename), ".cxx");
} else if (name[0] == '.') {
+ if (!proj_filename) return std::string{};
return fl_filename_setext_str(fl_filename_name(proj_filename), code_file_name);
} else {
return name;
@@ -130,8 +134,10 @@ std::string Project::headerfile_path() const {
std::string Project::headerfile_name() const {
std::string name = fl_filename_name_str(header_file_name);
if (name.empty()) {
+ if (!proj_filename) return std::string{};
return fl_filename_setext_str(fl_filename_name_str(proj_filename), ".h");
} else if (name[0] == '.') {
+ if (!proj_filename) return std::string{};
return fl_filename_setext_str(fl_filename_name_str(proj_filename), header_file_name);
} else {
return name;
@@ -158,6 +164,7 @@ std::string Project::stringsfile_path() const {
\return the file name without path
*/
std::string Project::stringsfile_name() const {
+ if (!proj_filename) return std::string{};
switch (i18n.type) {
default: return fl_filename_setext_str(fl_filename_name(proj_filename), ".txt");
case fld::I18n_Type::GNU: return fl_filename_setext_str(fl_filename_name(proj_filename), ".po");
@@ -170,6 +177,7 @@ std::string Project::stringsfile_name() const {
\return the file name without path or extension
*/
std::string Project::basename() const {
+ if (!proj_filename) return std::string{};
return fl_filename_setext_str(fl_filename_name(proj_filename), "");
}