mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-08-13 21:09:23 +02:00
IDE: Allow renaming a project using the Save As dialog. Issue #39954.
This commit is contained in:
parent
d20728f3a4
commit
18ac301d9d
@ -7593,7 +7593,8 @@ var
|
|||||||
SaveDialog: TSaveDialog;
|
SaveDialog: TSaveDialog;
|
||||||
NewBuf, OldBuf: TCodeBuffer;
|
NewBuf, OldBuf: TCodeBuffer;
|
||||||
TitleWasDefault: Boolean;
|
TitleWasDefault: Boolean;
|
||||||
NewLPIFilename, NewProgramFN, NewProgramName, AFilename: String;
|
AFilename, NewPath: String;
|
||||||
|
NewLPIFilename, NewProgramFN, NewProgramName, LCProgramName: String;
|
||||||
AText, ACaption, Ext: string;
|
AText, ACaption, Ext: string;
|
||||||
OldSourceCode, OldProjectDir, prDir: string;
|
OldSourceCode, OldProjectDir, prDir: string;
|
||||||
begin
|
begin
|
||||||
@ -7601,21 +7602,21 @@ begin
|
|||||||
Project1.BeginUpdate(false);
|
Project1.BeginUpdate(false);
|
||||||
try
|
try
|
||||||
OldProjectDir := Project1.Directory;
|
OldProjectDir := Project1.Directory;
|
||||||
if Assigned(Project1.MainUnitInfo) then
|
if Project1.IsVirtual then
|
||||||
begin
|
|
||||||
// build a nice project info filename suggestion
|
|
||||||
AFileName := Project1.MainUnitInfo.ReadUnitNameFromSource(false);
|
|
||||||
Assert(AFilename<>'', 'ShowSaveProjectAsDialog: UnitNameFromSource is empty.');
|
|
||||||
NewProgramName := AFilename;
|
|
||||||
end
|
|
||||||
else
|
|
||||||
UseMainSourceFile := False;
|
UseMainSourceFile := False;
|
||||||
|
// ToDo: If this assertion never triggers, the code can be simplified a lot.
|
||||||
|
Assert(not UseMainSourceFile, 'ShowSaveProjectAsDialog: UseMainSourceFile is still on.');
|
||||||
|
|
||||||
|
// build a nice project info filename suggestion
|
||||||
|
if Assigned(Project1.MainUnitInfo) then
|
||||||
|
AFileName := Project1.MainUnitInfo.ReadUnitNameFromSource(false);
|
||||||
if AFilename = '' then
|
if AFilename = '' then
|
||||||
AFilename := ExtractFileName(Project1.ProjectInfoFile);
|
AFilename := ExtractFileName(Project1.ProjectInfoFile);
|
||||||
if AFilename = '' then
|
if AFilename = '' then
|
||||||
AFilename := Trim(Project1.GetTitle);
|
AFilename := Trim(Project1.GetTitle);
|
||||||
if AFilename = '' then
|
if AFilename = '' then
|
||||||
AFilename := 'Project1';
|
AFilename := 'Project1';
|
||||||
|
// Figure out a filename extension
|
||||||
Ext := ExtractFileExt(AFilename);
|
Ext := ExtractFileExt(AFilename);
|
||||||
if UseMainSourceFile then
|
if UseMainSourceFile then
|
||||||
begin
|
begin
|
||||||
@ -7625,16 +7626,17 @@ begin
|
|||||||
if (Ext = '') or FilenameIsPascalSource(AFilename) then
|
if (Ext = '') or FilenameIsPascalSource(AFilename) then
|
||||||
AFilename := ChangeFileExt(AFilename, '.lpi');
|
AFilename := ChangeFileExt(AFilename, '.lpi');
|
||||||
end;
|
end;
|
||||||
// apply naming conventions, suggest lowercased name if user wants so
|
|
||||||
if EnvironmentOptions.LowercaseDefaultFilename then
|
|
||||||
AFilename := LowerCase(AFilename);
|
|
||||||
Ext := ExtractFileExt(AFilename);
|
Ext := ExtractFileExt(AFilename);
|
||||||
|
//DebugLn(['ShowSaveProjectAsDialog: 1. AFilename=',AFilename]);
|
||||||
|
|
||||||
SaveDialog := IDESaveDialogClass.Create(nil);
|
SaveDialog := IDESaveDialogClass.Create(nil);
|
||||||
try
|
try
|
||||||
InputHistories.ApplyFileDialogSettings(SaveDialog);
|
InputHistories.ApplyFileDialogSettings(SaveDialog);
|
||||||
SaveDialog.Title := Format(lisSaveProject, [Project1.GetTitleOrName, Ext]);
|
SaveDialog.Title := Format(lisSaveProject, [Project1.GetTitleOrName, Ext]);
|
||||||
SaveDialog.FileName := AFilename;
|
if EnvironmentOptions.LowercaseDefaultFilename then
|
||||||
|
SaveDialog.FileName := LowerCase(AFilename)
|
||||||
|
else
|
||||||
|
SaveDialog.FileName := AFilename;
|
||||||
// Note: add *.* filter, so users can see the files in the target directory
|
// Note: add *.* filter, so users can see the files in the target directory
|
||||||
SaveDialog.Filter := '*' + Ext + '|' + '*' + Ext
|
SaveDialog.Filter := '*' + Ext + '|' + '*' + Ext
|
||||||
+ '|' + dlgFilterAll + ' (' + GetAllFilesMask + ')|' + GetAllFilesMask;
|
+ '|' + dlgFilterAll + ' (' + GetAllFilesMask + ')|' + GetAllFilesMask;
|
||||||
@ -7649,12 +7651,11 @@ begin
|
|||||||
|
|
||||||
if not SaveDialog.Execute then
|
if not SaveDialog.Execute then
|
||||||
exit; // user cancels
|
exit; // user cancels
|
||||||
AFilename:=ExpandFileNameUTF8(SaveDialog.FileName);
|
AFilename := ExpandFileNameUTF8(SaveDialog.FileName);
|
||||||
Assert(FilenameIsAbsolute(AFilename),'ShowSaveProjectAsDialog: buggy ExpandFileNameUTF8');
|
//DebugLn(['ShowSaveProjectAsDialog: 2. AFilename=',AFilename]);
|
||||||
|
|
||||||
// check program name
|
// check program name
|
||||||
if NewProgramName='' then
|
NewProgramName:=ExtractFileNameOnly(AFilename);
|
||||||
NewProgramName:=ExtractFileNameOnly(AFilename);
|
|
||||||
if (NewProgramName='') or (not IsValidUnitName(NewProgramName)) then begin
|
if (NewProgramName='') or (not IsValidUnitName(NewProgramName)) then begin
|
||||||
Result:=IDEMessageDialog(lisInvalidProjectFilename,
|
Result:=IDEMessageDialog(lisInvalidProjectFilename,
|
||||||
Format(lisisAnInvalidProjectNamePleaseChooseAnotherEGProject,[SaveDialog.Filename,LineEnding]),
|
Format(lisisAnInvalidProjectNamePleaseChooseAnotherEGProject,[SaveDialog.Filename,LineEnding]),
|
||||||
@ -7663,33 +7664,25 @@ begin
|
|||||||
continue; // try again
|
continue; // try again
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
NewPath := ExtractFilePath(AFilename);
|
||||||
|
LCProgramName := NewProgramName;
|
||||||
|
// apply naming conventions, suggest lowercased name if user wants so
|
||||||
|
if EnvironmentOptions.LowercaseDefaultFilename then
|
||||||
|
LCProgramName := LowerCase(LCProgramName);
|
||||||
// append default extension
|
// append default extension
|
||||||
if UseMainSourceFile then
|
NewLPIFilename := NewPath + LCProgramName + '.lpi';
|
||||||
NewLPIFilename := ChangeFileExt(AFilename,'.lpi')
|
|
||||||
else
|
|
||||||
begin
|
|
||||||
NewLPIFilename := AFilename;
|
|
||||||
if ExtractFileExt(NewLPIFilename)='' then
|
|
||||||
NewLPIFilename := NewLPIFilename+'.lpi';
|
|
||||||
end;
|
|
||||||
|
|
||||||
if Project1.MainUnitID >= 0 then
|
if Project1.MainUnitID >= 0 then
|
||||||
begin
|
begin
|
||||||
// check mainunit filename
|
// check mainunit filename
|
||||||
Ext := ExtractFileExt(Project1.MainUnitInfo.Filename);
|
Ext := ExtractFileExt(Project1.MainUnitInfo.Filename);
|
||||||
if Ext = '' then begin
|
Assert(Ext<>'', 'ShowSaveProjectAsDialog: Ext is empty');
|
||||||
Ext := '.pas';
|
|
||||||
DebugLn('ShowSaveProjectAsDialog: Forced suffix to be .pas');
|
|
||||||
end;
|
|
||||||
if UseMainSourceFile then
|
if UseMainSourceFile then
|
||||||
NewProgramFN := ExtractFileName(AFilename)
|
NewProgramFN := ExtractFileName(AFilename)
|
||||||
else begin
|
else
|
||||||
NewProgramFN := NewProgramName + Ext;
|
NewProgramFN := LCProgramName + Ext;
|
||||||
if EnvironmentOptions.LowercaseDefaultFilename then
|
NewProgramFN := NewPath + NewProgramFN;
|
||||||
NewProgramFN := LowerCase(NewProgramFN);
|
if CompareFilenames(NewLPIFilename, NewProgramFN) = 0 then
|
||||||
end;
|
|
||||||
NewProgramFN := ExtractFilePath(NewLPIFilename) + NewProgramFN;
|
|
||||||
if (CompareFilenames(NewLPIFilename, NewProgramFN) = 0) then
|
|
||||||
begin
|
begin
|
||||||
ACaption:=lisChooseADifferentName;
|
ACaption:=lisChooseADifferentName;
|
||||||
AText:=Format(lisTheProjectInfoFileIsEqualToTheProjectMainSource,[NewLPIFilename,LineEnding]);
|
AText:=Format(lisTheProjectInfoFileIsEqualToTheProjectMainSource,[NewLPIFilename,LineEnding]);
|
||||||
@ -7718,7 +7711,7 @@ begin
|
|||||||
SaveDialog.Free;
|
SaveDialog.Free;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
//DebugLn(['ShowSaveProjectAsDialog NewLPI=',NewLPIFilename,' NewProgramName=',NewProgramName,
|
//DebugLn(['ShowSaveProjectAsDialog: NewLPI=',NewLPIFilename,' NewProgramName=',NewProgramName,
|
||||||
// ' NewMainSource=',NewProgramFN]);
|
// ' NewMainSource=',NewProgramFN]);
|
||||||
// check if info file or source file already exists
|
// check if info file or source file already exists
|
||||||
// Note: if user confirms overwriting .lpi do not ask for overwriting .lpr
|
// Note: if user confirms overwriting .lpi do not ask for overwriting .lpr
|
||||||
|
Loading…
Reference in New Issue
Block a user