Merge pull request #374 from Zevenberge/feature/add_folder

Create a directory and package.d
This commit is contained in:
Vadim Lopatin 2018-05-08 10:31:15 +03:00 committed by GitHub
commit 6c32105caf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 560 additions and 295 deletions

4
.gitignore vendored
View File

@ -20,3 +20,7 @@ index.html
api.html api.html
screenshots.html screenshots.html
*.log *.log
*.userprefs
\.dlangidews\.wssettings

View File

@ -443,6 +443,7 @@
<Link>3rdparty\dsymbol\symbols.d</Link> <Link>3rdparty\dsymbol\symbols.d</Link>
</Compile> </Compile>
<Compile Include="src\dlangide\ui\terminal.d" /> <Compile Include="src\dlangide\ui\terminal.d" />
<Compile Include="src\dlangide\ui\newfolder.d" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Folder Include="src\ddebug\gdb\" /> <Folder Include="src\ddebug\gdb\" />

View File

@ -938,6 +938,7 @@
<File path="src\dlangide\ui\frame.d" /> <File path="src\dlangide\ui\frame.d" />
<File path="src\dlangide\ui\homescreen.d" /> <File path="src\dlangide\ui\homescreen.d" />
<File path="src\dlangide\ui\newfile.d" /> <File path="src\dlangide\ui\newfile.d" />
<File path="src\dlangide\ui\newfolder.d" />
<File path="src\dlangide\ui\newproject.d" /> <File path="src\dlangide\ui\newproject.d" />
<File path="src\dlangide\ui\outputpanel.d" /> <File path="src\dlangide\ui\outputpanel.d" />
<File path="src\dlangide\ui\searchPanel.d" /> <File path="src\dlangide\ui\searchPanel.d" />

View File

@ -6,6 +6,7 @@ import dlangui.widgets.editors;
enum IDEActions : int { enum IDEActions : int {
//ProjectOpen = 1010000, //ProjectOpen = 1010000,
FileNew = 1010000, FileNew = 1010000,
FileNewDirectory,
FileNewWorkspace, FileNewWorkspace,
FileNewProject, FileNewProject,
FileOpen, FileOpen,
@ -100,6 +101,7 @@ const Action ACTION_PROJECT_FOLDER_COLLAPSE_ALL = new Action(IDEActions.ProjectF
const Action ACTION_FILE_WORKSPACE_CLOSE = new Action(IDEActions.CloseWorkspace, "MENU_FILE_WORKSPACE_CLOSE"c).disableByDefault(); const Action ACTION_FILE_WORKSPACE_CLOSE = new Action(IDEActions.CloseWorkspace, "MENU_FILE_WORKSPACE_CLOSE"c).disableByDefault();
const Action ACTION_FILE_NEW_DIRECTORY = new Action(IDEActions.FileNewDirectory, "MENU_FILE_NEW_DIRECTORY"c);
const Action ACTION_FILE_NEW_SOURCE_FILE = new Action(IDEActions.FileNew, "MENU_FILE_NEW_SOURCE_FILE"c, "document-new", KeyCode.KEY_N, KeyFlag.Control); const Action ACTION_FILE_NEW_SOURCE_FILE = new Action(IDEActions.FileNew, "MENU_FILE_NEW_SOURCE_FILE"c, "document-new", KeyCode.KEY_N, KeyFlag.Control);
const Action ACTION_FILE_NEW_PROJECT = new Action(IDEActions.FileNewProject, "MENU_FILE_NEW_PROJECT"c); const Action ACTION_FILE_NEW_PROJECT = new Action(IDEActions.FileNewProject, "MENU_FILE_NEW_PROJECT"c);
const Action ACTION_FILE_NEW_WORKSPACE = new Action(IDEActions.FileNewWorkspace, "MENU_FILE_NEW_WORKSPACE"c); const Action ACTION_FILE_NEW_WORKSPACE = new Action(IDEActions.FileNewWorkspace, "MENU_FILE_NEW_WORKSPACE"c);

View File

@ -21,6 +21,7 @@ import dlangide.ui.commands;
import dlangide.ui.wspanel; import dlangide.ui.wspanel;
import dlangide.ui.outputpanel; import dlangide.ui.outputpanel;
import dlangide.ui.newfile; import dlangide.ui.newfile;
import dlangide.ui.newfolder;
import dlangide.ui.newproject; import dlangide.ui.newproject;
import dlangide.ui.dsourceedit; import dlangide.ui.dsourceedit;
import dlangide.ui.homescreen; import dlangide.ui.homescreen;
@ -416,6 +417,13 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
} }
} }
bool tryOpenSourceFile(string filename) {
if (isSupportedSourceTextFileFormat(filename)) {
return openSourceFile(filename, null, true);
}
return false;
}
bool openSourceFile(string filename, ProjectSourceFile file = null, bool activate = true) { bool openSourceFile(string filename, ProjectSourceFile file = null, bool activate = true) {
if (!file && !filename) if (!file && !filename)
return false; return false;
@ -1137,7 +1145,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
else else
ed.editorTool = new DefaultEditorTool(this); ed.editorTool = new DefaultEditorTool(this);
//openSourceFile(filename); //openSourceFile(filename);
refreshWorkspace(); updateTreeGraph();
ProjectSourceFile file = _wsPanel.findSourceFileItem(filename, false); ProjectSourceFile file = _wsPanel.findSourceFileItem(filename, false);
if (file) { if (file) {
ed.projectSourceFile = file; ed.projectSourceFile = file;
@ -1209,7 +1217,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
buildProject(BuildOperation.Upgrade, cast(Project)a.objectParam); buildProject(BuildOperation.Upgrade, cast(Project)a.objectParam);
return true; return true;
case IDEActions.RefreshProject: case IDEActions.RefreshProject:
refreshWorkspace(); updateTreeGraph();
return true; return true;
case IDEActions.RevealProjectInExplorer: case IDEActions.RevealProjectInExplorer:
revealProjectInExplorer(cast(Project)a.objectParam); revealProjectInExplorer(cast(Project)a.objectParam);
@ -1365,7 +1373,10 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
createNewProject(false); createNewProject(false);
return true; return true;
case IDEActions.FileNew: case IDEActions.FileNew:
addProjectItem(cast(Object)a.objectParam); addFile(cast(Object)a.objectParam);
return true;
case IDEActions.FileNewDirectory:
addDirectory(cast(Object)a.objectParam);
return true; return true;
case IDEActions.ProjectFolderRemoveItem: case IDEActions.ProjectFolderRemoveItem:
removeProjectItem(a.objectParam); removeProjectItem(a.objectParam);
@ -1433,7 +1444,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
if (cast(Workspace)obj) { if (cast(Workspace)obj) {
Workspace ws = cast(Workspace)obj; Workspace ws = cast(Workspace)obj;
ws.refresh(); ws.refresh();
refreshWorkspace(); updateTreeGraph();
} else if (cast(Project)obj) { } else if (cast(Project)obj) {
project = cast(Project)obj; project = cast(Project)obj;
} else if (cast(ProjectFolder)obj) { } else if (cast(ProjectFolder)obj) {
@ -1452,7 +1463,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
} }
if (project) { if (project) {
project.refresh(); project.refresh();
refreshWorkspace(); updateTreeGraph();
} }
} }
@ -1479,7 +1490,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
Log.e("Cannot remove file"); Log.e("Cannot remove file");
} }
project.refresh(); project.refresh();
refreshWorkspace(); updateTreeGraph();
} }
// else ignore // else ignore
return true; return true;
@ -1487,8 +1498,53 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
} }
private void addFile(Object obj) {
Dialog createNewFileDialog(Project project, ProjectFolder folder) {
NewFileDlg dialog = new NewFileDlg(this, project, folder);
dialog.dialogResult = delegate(Dialog dlg, const Action result) {
if (result.id == ACTION_FILE_NEW_SOURCE_FILE.id) {
FileCreationResult res = cast(FileCreationResult)result.objectParam;
if (res) {
//res.project.reload();
res.project.refresh();
updateTreeGraph();
tryOpenSourceFile(res.filename);
}
}
};
return dialog;
}
addProjectItem(&createNewFileDialog, obj);
}
private void addDirectory(Object obj) {
Dialog createNewDirectoryDialog(Project project, ProjectFolder folder) {
NewFolderDialog dialog = new NewFolderDialog(this, project, folder);
dialog.dialogResult = delegate(Dialog dlg, const Action result) {
if(result.id == ACTION_FILE_NEW_DIRECTORY.id) {
FileCreationResult res = cast(FileCreationResult)result.objectParam;
if (res) {
ProjectFolder newFolder = new ProjectFolder(res.filename);
if(folder) {
folder.addChild(newFolder);
folder.sortItems;
newFolder.refresh();
if(newFolder.childCount > 0){
tryOpenSourceFile(newFolder.child(0).filename);
}
}
updateTreeGraph();
_wsPanel.selectItem(newFolder);
}
}
};
return dialog;
}
addProjectItem(&createNewDirectoryDialog, obj);
}
/// add new file to project /// add new file to project
void addProjectItem(Object obj) { private void addProjectItem(Dialog delegate(Project, ProjectFolder) dialogFactory, Object obj) {
if (currentWorkspace is null) if (currentWorkspace is null)
return; return;
if (obj is null && _wsPanel !is null && !currentEditorSourceFile) { if (obj is null && _wsPanel !is null && !currentEditorSourceFile) {
@ -1500,7 +1556,12 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
ProjectFolder folder; ProjectFolder folder;
if (cast(Project)obj) { if (cast(Project)obj) {
project = cast(Project)obj; project = cast(Project)obj;
folder = project.firstSourceFolder; folder = project.items;
import std.stdio;
writeln("Root filename:", folder.filename);
for(int i = 0; i < folder.childCount; i++) {
writeln("Child [", i, "]: ", folder.child(i).filename);
}
} else if (cast(ProjectFolder)obj) { } else if (cast(ProjectFolder)obj) {
folder = cast(ProjectFolder)obj; folder = cast(ProjectFolder)obj;
project = folder.project; project = folder.project;
@ -1515,21 +1576,8 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
project = srcfile.project; project = srcfile.project;
} }
} }
if (project && folder && project.workspace is currentWorkspace) { if (project && project.workspace is currentWorkspace) {
NewFileDlg dlg = new NewFileDlg(this, project, folder); Dialog dlg = dialogFactory(project, folder);
dlg.dialogResult = delegate(Dialog dlg, const Action result) {
if (result.id == ACTION_FILE_NEW_SOURCE_FILE.id) {
FileCreationResult res = cast(FileCreationResult)result.objectParam;
if (res) {
//res.project.reload();
res.project.refresh();
refreshWorkspace();
if (isSupportedSourceTextFileFormat(res.filename)) {
openSourceFile(res.filename, null, true);
}
}
}
};
dlg.show(); dlg.show();
} }
} }
@ -1550,12 +1598,12 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
if (currentWorkspace is null || res.workspace !is currentWorkspace) { if (currentWorkspace is null || res.workspace !is currentWorkspace) {
// open new workspace // open new workspace
setWorkspace(res.workspace); setWorkspace(res.workspace);
refreshWorkspace(); updateTreeGraph();
hideHomeScreen(); hideHomeScreen();
} else { } else {
// project added to current workspace // project added to current workspace
loadProject(res.project); loadProject(res.project);
refreshWorkspace(); updateTreeGraph();
hideHomeScreen(); hideHomeScreen();
} }
} }
@ -1757,7 +1805,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
currentWorkspace.addProject(project); currentWorkspace.addProject(project);
loadProject(project); loadProject(project);
currentWorkspace.save(); currentWorkspace.save();
refreshWorkspace(); updateTreeGraph();
hideHomeScreen(); hideHomeScreen();
} }
return true; return true;
@ -1772,7 +1820,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
} }
} }
void refreshWorkspace() { void updateTreeGraph() {
_logPanel.logLine("Refreshing workspace"); _logPanel.logLine("Refreshing workspace");
_wsPanel.reloadItems(); _wsPanel.reloadItems();
closeRemovedDocuments(); closeRemovedDocuments();
@ -1838,7 +1886,7 @@ class IDEFrame : AppFrame, ProgramExecutionStatusListener, BreakpointListChangeL
void refreshProject(Project project) { void refreshProject(Project project) {
if (currentWorkspace && project.loadSelections()) { if (currentWorkspace && project.loadSelections()) {
currentWorkspace.cleanupUnusedDependencies(); currentWorkspace.cleanupUnusedDependencies();
refreshWorkspace(); updateTreeGraph();
} }
} }

View File

@ -198,29 +198,6 @@ class NewFileDlg : Dialog {
ProjectTemplate _currentTemplate; ProjectTemplate _currentTemplate;
ProjectTemplate[] _templates; ProjectTemplate[] _templates;
static bool isSubdirOf(string path, string basePath) {
if (path.equal(basePath))
return true;
if (path.length > basePath.length + 1 && path.startsWith(basePath)) {
char ch = path[basePath.length];
return ch == '/' || ch == '\\';
}
return false;
}
bool findSource(string path, ref string sourceFolderPath, ref string relativePath) {
foreach(dir; _sourcePaths) {
if (isSubdirOf(path, dir)) {
sourceFolderPath = dir;
relativePath = path[sourceFolderPath.length .. $];
if (relativePath.length > 0 && (relativePath[0] == '\\' || relativePath[0] == '/'))
relativePath = relativePath[1 .. $];
return true;
}
}
return false;
}
bool setError(dstring msg) { bool setError(dstring msg) {
_statusText.text = msg; _statusText.text = msg;
return msg.empty; return msg.empty;
@ -242,25 +219,12 @@ class NewFileDlg : Dialog {
if (_currentTemplate.kind == FileKind.MODULE || _currentTemplate.kind == FileKind.PACKAGE) { if (_currentTemplate.kind == FileKind.MODULE || _currentTemplate.kind == FileKind.PACKAGE) {
string sourcePath, relativePath; string sourcePath, relativePath;
if (!findSource(_location, sourcePath, relativePath)) if (!findSource(_sourcePaths, _location, sourcePath, relativePath))
return setError("Location is outside of source path"); return setError("Location is outside of source path");
if (!isValidModuleName(filename)) if (!isValidModuleName(filename))
return setError("Invalid file name"); return setError("Invalid file name");
_moduleName = filename; _moduleName = filename;
char[] buf; _packageName = getPackageName(sourcePath, relativePath);
foreach(c; relativePath) {
char ch = c;
if (ch == '/' || ch == '\\')
ch = '.';
else if (ch == '.')
ch = '_';
if (ch == '.' && (buf.length == 0 || buf[$-1] == '.'))
continue; // skip duplicate .
buf ~= ch;
}
if (buf.length && buf[$-1] == '.')
buf.length--;
_packageName = buf.dup;
string m; string m;
if (_currentTemplate.kind == FileKind.MODULE) { if (_currentTemplate.kind == FileKind.MODULE) {
m = !_packageName.empty ? _packageName ~ '.' ~ _moduleName : _moduleName; m = !_packageName.empty ? _packageName ~ '.' ~ _moduleName : _moduleName;
@ -284,20 +248,10 @@ class NewFileDlg : Dialog {
private FileCreationResult _result; private FileCreationResult _result;
bool createItem() { bool createItem() {
try { if(!createFile(_fullPathName, _currentTemplate.kind, _packageName, _currentTemplate.srccode)) {
if (_currentTemplate.kind == FileKind.MODULE) {
string txt = "module " ~ _packageName ~ ";\n\n" ~ _currentTemplate.srccode;
write(_fullPathName, txt);
} else if (_currentTemplate.kind == FileKind.PACKAGE) {
string txt = "module " ~ _packageName ~ ";\n\n" ~ _currentTemplate.srccode;
write(_fullPathName, txt);
} else {
write(_fullPathName, _currentTemplate.srccode);
}
} catch (Exception e) {
Log.e("Cannot create file", e);
return setError("Cannot create file"); return setError("Cannot create file");
} }
_result = new FileCreationResult(_project, _fullPathName); _result = new FileCreationResult(_project, _fullPathName);
return true; return true;
} }
@ -377,3 +331,67 @@ class ProjectTemplate {
this.kind = kind; this.kind = kind;
} }
} }
bool createFile(string fullPathName, FileKind fileKind, string packageName, string sourceCode) {
try {
if (fileKind == FileKind.MODULE) {
string txt = "module " ~ packageName ~ ";\n\n" ~ sourceCode;
write(fullPathName, txt);
} else if (fileKind == FileKind.PACKAGE) {
string txt = "module " ~ packageName ~ ";\n\n" ~ sourceCode;
write(fullPathName, txt);
} else {
write(fullPathName, sourceCode);
}
return true;
}
catch(Exception e) {
Log.e("Cannot create file", e);
return false;
}
}
string getPackageName(string path, string[] sourcePaths){
string sourcePath, relativePath;
if(!findSource(sourcePaths, path, sourcePath, relativePath)) return "";
return getPackageName(sourcePath, relativePath);
}
string getPackageName(string sourcePath, string relativePath){
char[] buf;
foreach(c; relativePath) {
char ch = c;
if (ch == '/' || ch == '\\')
ch = '.';
else if (ch == '.')
ch = '_';
if (ch == '.' && (buf.length == 0 || buf[$-1] == '.'))
continue; // skip duplicate .
buf ~= ch;
}
if (buf.length && buf[$-1] == '.')
buf.length--;
return buf.dup;
}
private bool findSource(string[] sourcePaths, string path, ref string sourceFolderPath, ref string relativePath) {
foreach(dir; sourcePaths) {
if (isSubdirOf(path, dir)) {
sourceFolderPath = dir;
relativePath = path[sourceFolderPath.length .. $];
if (relativePath.length > 0 && (relativePath[0] == '\\' || relativePath[0] == '/'))
relativePath = relativePath[1 .. $];
return true;
}
}
return false;
}
private bool isSubdirOf(string path, string basePath) {
if (path.equal(basePath))
return true;
if (path.length > basePath.length + 1 && path.startsWith(basePath)) {
char ch = path[basePath.length];
return ch == '/' || ch == '\\';
}
return false;
}

186
src/dlangide/ui/newfolder.d Normal file
View File

@ -0,0 +1,186 @@
module dlangide.ui.newfolder;
import std.array : empty;
import std.file : mkdir, exists;
import std.path : buildPath, buildNormalizedPath;
import std.utf : toUTF32;
import dlangui.core.logger;
import dlangui.core.stdaction;
import dlangui.dialogs.dialog;
import dlangui.dml.parser;
import dlangui.widgets.controls;
import dlangui.widgets.editors;
import dlangui.widgets.widget;
import dlangide.ui.commands;
import dlangide.ui.frame;
import dlangide.ui.newfile;
import dlangide.workspace.project;
class NewFolderDialog : Dialog {
private {
IDEFrame _ide;
Project _project;
ProjectFolder _folder;
string _location;
}
this(IDEFrame parent, Project currentProject, ProjectFolder folder) {
super(UIString.fromId("OPTION_NEW_SOURCE_FILE"c), parent.window,
DialogFlag.Modal | DialogFlag.Popup, 800, 0);
layoutWidth = FILL_PARENT;
_ide = parent;
_icon = "dlangui-logo1";
this._project = currentProject;
this._folder = folder;
if (folder){
_location = folder.filename;
}
else {
_location = currentProject.dir;
}
}
override void initialize() {
super.initialize();
Widget content;
try {
content = parseML(q{
VerticalLayout {
id: vlayout
padding: Rect { 5, 5, 5, 5 }
layoutWidth: fill; layoutHeight: wrap
TableLayout {
margins: 5
colCount: 2
layoutWidth: fill; layoutHeight: wrap
TextWidget { text: NAME }
EditLine { id: fileName; text: "newfolder"; layoutWidth: fill }
CheckBox { id: makePackage }
TextWidget { text: OPTION_MAKE_PACKAGE}
}
TextWidget { id: statusText; text: ""; layoutWidth: fill; textColor: #FF0000 }
}
});
} catch (Exception e) {
Log.e("Exceptin while parsing DML", e);
throw e;
}
_edFileName = content.childById!EditLine("fileName");
_edMakePackage = content.childById!CheckBox("makePackage");
_statusText = content.childById!TextWidget("statusText");
_edFileName.enterKey.connect(&onEnterKey);
_edFileName.setDefaultPopupMenu();
_edFileName.contentChange = delegate (EditableContent source) {
updateValues(source.text);
validate();
};
addChild(content);
addChild(createButtonsPanel([ACTION_FILE_NEW_DIRECTORY, ACTION_CANCEL], 0, 0));
updateValues(_edFileName.text);
}
override void onShow() {
super.onShow();
_edFileName.selectAll();
_edFileName.setFocus();
}
protected bool onEnterKey(EditWidgetBase editor) {
if (!validate())
return false;
close(_buttonActions[0]);
return true;
}
private bool validate() {
if (!isValidModuleName(_fileName))
return setError("Invalid folder name");
return setError(null);
}
private void updateValues(dstring fileName) {
_fileName = toUTF8(fileName);
}
private bool setError(dstring msg) {
_statusText.text = msg;
return msg.empty;
}
private {
EditLine _edFileName;
CheckBox _edMakePackage;
TextWidget _statusText;
string _fileName = "newfile";
FileCreationResult _result;
bool shouldMakePackage() @property {
return _edMakePackage.checked;
}
string fullPathName() @property {
return buildNormalizedPath(_location, _fileName);
}
}
private bool createItem() {
string fullPathName = this.fullPathName;
if(exists(fullPathName))
return setError("Folder already exists");
if(!makeDirectory(fullPathName)) return false;
if(shouldMakePackage) {
if(!makePackageFile(fullPathName)) {
return false;
}
}
_result = new FileCreationResult(_project, fullPathName);
return true;
}
private bool makeDirectory(string fullPathName) {
try {
mkdir(fullPathName);
return true;
} catch (Exception e) {
Log.e("Cannot create folder", e);
return setError("Cannot create folder");
}
}
private bool makePackageFile(string fullPathName) {
string packageName = getPackageName(fullPathName, _project.sourcePaths);
if(packageName.empty) {
Log.e("Could not determing package name for ", fullPathName);
return false;
}
if(!createFile(fullPathName.buildPath("package.d"), FileKind.PACKAGE, packageName, null)) {
Log.e("Could not create package file in folder ", fullPathName);
return false;
}
return true;
}
override void close(const Action action) {
Action newaction = action.clone();
if (action.id == IDEActions.FileNewDirectory) {
if (!validate()) {
window.showMessageBox(UIString.fromId("ERROR"c), UIString.fromId("ERROR_INVALID_PARAMETERS"c));
return;
}
if (!createItem()) {
window.showMessageBox(UIString.fromId("ERROR"c), UIString.fromId("ERROR_INVALID_PARAMETERS"c));
return;
}
newaction.objectParam = _result;
}
super.close(newaction);
}
}

View File

@ -102,7 +102,7 @@ class WorkspacePanel : DockWindow {
_projectPopupMenu = new MenuItem(); _projectPopupMenu = new MenuItem();
_projectPopupMenu.add(ACTION_PROJECT_SET_STARTUP, _projectPopupMenu.add(ACTION_PROJECT_SET_STARTUP,
ACTION_PROJECT_FOLDER_REFRESH, ACTION_PROJECT_FOLDER_REFRESH,
ACTION_FILE_NEW_SOURCE_FILE, //ACTION_FILE_NEW_DIRECTORY,
//ACTION_PROJECT_FOLDER_OPEN_ITEM, //ACTION_PROJECT_FOLDER_OPEN_ITEM,
ACTION_PROJECT_BUILD, ACTION_PROJECT_BUILD,
ACTION_PROJECT_REBUILD, ACTION_PROJECT_REBUILD,
@ -116,14 +116,17 @@ class WorkspacePanel : DockWindow {
); );
_folderPopupMenu = new MenuItem(); _folderPopupMenu = new MenuItem();
_folderPopupMenu.add(ACTION_FILE_NEW_SOURCE_FILE, ACTION_PROJECT_FOLDER_REFRESH, ACTION_PROJECT_FOLDER_OPEN_ITEM, _folderPopupMenu.add(ACTION_FILE_NEW_SOURCE_FILE,
ACTION_FILE_NEW_DIRECTORY,
ACTION_PROJECT_FOLDER_REFRESH, ACTION_PROJECT_FOLDER_OPEN_ITEM,
ACTION_PROJECT_FOLDER_EXPAND_ALL, ACTION_PROJECT_FOLDER_COLLAPSE_ALL ACTION_PROJECT_FOLDER_EXPAND_ALL, ACTION_PROJECT_FOLDER_COLLAPSE_ALL
//ACTION_PROJECT_FOLDER_REMOVE_ITEM, //ACTION_PROJECT_FOLDER_REMOVE_ITEM,
//ACTION_PROJECT_FOLDER_RENAME_ITEM //ACTION_PROJECT_FOLDER_RENAME_ITEM
); );
_filePopupMenu = new MenuItem(); _filePopupMenu = new MenuItem();
_filePopupMenu.add(ACTION_FILE_NEW_SOURCE_FILE, ACTION_PROJECT_FOLDER_REFRESH, _filePopupMenu.add(ACTION_FILE_NEW_SOURCE_FILE,
ACTION_PROJECT_FOLDER_REFRESH,
ACTION_PROJECT_FOLDER_OPEN_ITEM, ACTION_PROJECT_FOLDER_OPEN_ITEM,
ACTION_PROJECT_FOLDER_REMOVE_ITEM, ACTION_PROJECT_FOLDER_REMOVE_ITEM,
//ACTION_PROJECT_FOLDER_RENAME_ITEM //ACTION_PROJECT_FOLDER_RENAME_ITEM

View File

@ -422,7 +422,7 @@ class Project : WorkspaceItem {
includePath ~= obj.str; includePath ~= obj.str;
} }
_items = new ProjectFolder(fname); _items = new ProjectFolder(fname.dirName);
_dependencyVersion = dependencyVersion; _dependencyVersion = dependencyVersion;
_isDependency = _dependencyVersion.length > 0; _isDependency = _dependencyVersion.length > 0;
_projectFile = new SettingsFile(fname); _projectFile = new SettingsFile(fname);
@ -607,8 +607,8 @@ class Project : WorkspaceItem {
return settings.runInExternalConsole; return settings.runInExternalConsole;
} }
ProjectFolder findItems(string[] srcPaths) { private ProjectFolder findItems(string[] srcPaths) {
auto folder = new ProjectFolder(_filename); auto folder = new ProjectFolder(_filename.dirName);
folder.project = this; folder.project = this;
foreach(customPath; srcPaths) { foreach(customPath; srcPaths) {
string path = relativeToAbsolutePath(customPath); string path = relativeToAbsolutePath(customPath);

View File

@ -34,6 +34,7 @@ NAME=Name
MENU_FILE=&File MENU_FILE=&File
MENU_FILE_NEW=&Create MENU_FILE_NEW=&Create
MENU_FILE_NEW_SOURCE_FILE=New file MENU_FILE_NEW_SOURCE_FILE=New file
MENU_FILE_NEW_DIRECTORY=New directory
MENU_FILE_NEW_PROJECT=New project MENU_FILE_NEW_PROJECT=New project
MENU_FILE_NEW_WORKSPACE=New workspace MENU_FILE_NEW_WORKSPACE=New workspace
MENU_FILE_OPEN=&Open file... MENU_FILE_OPEN=&Open file...
@ -196,6 +197,7 @@ OPTION_GDC_EXECUTABLE=GDC executable
OPTION_LANGUAGE=Language OPTION_LANGUAGE=Language
OPTION_LDC2_EXECUTABLE=LDC2 executable OPTION_LDC2_EXECUTABLE=LDC2 executable
OPTION_LDMD2_EXECUTABLE=LDMD2 executable OPTION_LDMD2_EXECUTABLE=LDMD2 executable
OPTION_MAKE_PACKAGE=Create package.d
OPTION_MODULE_NAME=Module name OPTION_MODULE_NAME=Module name
OPTION_NEW_PROJECT=New project OPTION_NEW_PROJECT=New project
OPTION_NEW_SOURCE_FILE=New source file OPTION_NEW_SOURCE_FILE=New source file