dlangide 0.7.80

Cross platform D language IDE based on dlangui library


To use this package, run the following command in your project's root directory:

Manual usage
Put the following dependency into your project's dependences section:

Gitter Build Status PayPayl donate button

Dlang IDE

Cross platform D language IDE written using DlangUI library.

Currently supported features:

  • Uses DUB (dub.json or dub.sdl) project format
  • Shows tree with project source files
  • Can open and edit source files from project or file system in multi-tab editor
  • Build and run project with DUB
  • Build log highlight and navigation to place of error or warning by clicking on log line (contributed by Extrawurst)
  • DUB dependencies update
  • DUB package configuration selection (contributed by NCrashed)
  • Dependency projects are shown in workspace tree
  • New project wizard
  • Toolchain settings for DMD, LDC, GDC
  • Project specific settings
  • Basic debugger support using GDB (work in progress)

Source editor features:

  • D language source code, json, dml syntax highlight
  • Indent / unindent text with Tab and Shift+Tab or Ctrl+[ and Ctrl+]
  • Toggle line or block comments by Ctrl+/ and Ctrl+Shift+/
  • D source code autocompletion by Ctrl+Space or Ctrl+Shift+G (using DCD)
  • D source code Go To Definition by Ctrl+G or F12 (using DCD)
  • D source Doc comments display on mouse hover (using DCD)
  • D source code Smart Indents
  • Select word by mouse double click

screenshot

GitHub page: https://github.com/buggins/dlangide

Wiki: https://github.com/buggins/dlangide/wiki

DlangUI project GitHub page: https://github.com/buggins/dlangui

Mago debugger GitHub page: https://github.com/rainers/mago

Build tools

DlangIDE uses DUB as build tool, and its dub.json or dub.sdl as project file format. You can select DMD, LDC or GDC compiler toolchain.

DCD integration

Symbol lookup and autocompletion is using DCD (D completion daemon).

Hans-Albert Maritz (Freakazo) implementated DCD integration using DCD client/server.

Keywan Ghadami improved it to use DCD as a library.

Now DCD is embedded into DlangIDE, and no separate executables are needed.

Importing of existing project

DlangIDE supports only DUB project format.

To import existing DUB project, use menu item "File" / "Open project or workspace" and select dub.json or dub.sdl of your project to import.

Debugger support

  • Windows: use mago-mi debugger (https://github.com/buggins/dlangide/blob/master/libs/windows/x86/mago-mi.exe) or GDB
  • Linux: use GDB or lldb-mi debugger
  • OSX: use GDB or LLDBMI2 debugger

Building DlangIDE

Build and run with DUB:

git clone https://github.com/buggins/dlangide.git
cd dlangide
dub run

If you see build errors, try to upgrade dependencies:

dub clean-caches

dub upgrade --force-remove dub build --force

Needs DMD 2.066.1 or newer to build.

HINT: Try to open sample project Tetris, from workspaces/tetris with DlangIDE.

To develop in VisualD together with DlangUI, put this project on the same level as dlangui repository, and its dependencies.

Keyboard shortcut settings

Keyboard shortcuts settings support is added.

For linux and macos settings are placed in file

~/.dlangide/shortcuts.json

For Windows, in directory like

C:\Users\user\AppData\Roaming\.dlangide\shortcuts.json

If no such file exists, it's being created on DlangIDE start, filling with default values to simplify configuration.

Just edit its content to redefine some key bindings.

File format is simple and intuitive. Example:

{
    "EditorActions.Copy": "Ctrl+C",
    "EditorActions.Paste": "Ctrl+V",
    "EditorActions.Cut": "Ctrl+X",
    "EditorActions.Undo": "Ctrl+Z",
    "EditorActions.Redo": [
        "Ctrl+Y",
        "Ctrl+Shift+Z"
    ],
    "EditorActions.Indent": [
        "Tab",
        "Ctrl+]"
    ],
    "EditorActions.Unindent": [
        "Shift+Tab",
        "Ctrl+["
    ],
    "EditorActions.ToggleLineComment": "Ctrl+/",
    "EditorActions.ToggleBlockComment": "Ctrl+Shift+/"
}


Development environment setup

Howto hack DlangIDE.

For Windows, install MS Visual Studio (e.g. Community 2013) + VisualD plugin

Install GIT, DUB, DMD.

For Linux and OSX, install MonoDevelop + Mono-D plugin.

For Linux / OSX, additionally install libSDL2 and X11 development packages.

Create some folder to place sources, e.g. ~/src/d/

Clone DlangUI and DlangIDE repositories into source folder

git clone --recursive https://github.com/buggins/dlangui.git
git clone --recursive https://github.com/buggins/dlangide.git

Windows: open solution file with Visual-D

dlangui/dlangui-msvc.sln

Linux: open solution file with Mono-D

dlangide/dlangide-monod-linux.sln

OSX: open solution file with Mono-D

dlangide/dlangide-monod-osx.sln

Choose dlangide as startup project.

Coding style: https://github.com/buggins/dlangui/blob/master/CODING_STYLE.md

Workspace include path setting

Now you can set dmd includes paths (for correct work with DCD) in workspace settings file (newworkspace.dlangidews) <pre> example: {

"name" : "newworkspace",
"description" : null,
"projects" : {
        "newproject" : "newproject/dub.json"<br>
},
"includePath" : [
        "/usr/include/dlang/dmd/"
]

} </pre>

Authors:
  • Vadim Lopatin
Dependencies:
dsymbol, dcd, dlangui
Versions:
0.8.19 2024-Mar-12
0.8.18 2023-Apr-18
0.8.17 2018-Nov-26
0.8.16 2018-Nov-26
0.8.15 2018-Nov-26
Show all 319 versions
Download Stats:
  • 2 downloads today

  • 11 downloads this week

  • 37 downloads this month

  • 7300 downloads total

Score:
3.2
Short URL:
dlangide.dub.pm