diff --git a/docs/img/dub_register_package.png b/docs/img/dub_register_package.png new file mode 100644 index 00000000..0c198c5e Binary files /dev/null and b/docs/img/dub_register_package.png differ diff --git a/docs/img/library_manager.png b/docs/img/library_manager.png new file mode 100644 index 00000000..3c6564fe Binary files /dev/null and b/docs/img/library_manager.png differ diff --git a/docs/widgets_library_manager.md b/docs/widgets_library_manager.md index 0c874242..60074a5f 100644 --- a/docs/widgets_library_manager.md +++ b/docs/widgets_library_manager.md @@ -1,3 +1,51 @@ --- title: Widgets - library manager --- + +### Library manager + +#### Description + +The library manager (aka the _libman_) is designed to replace the _sc.ini_ or the _sc.conf_ file to manage the static libraries. +Despite of its simplistic look it's a central component of the software. The [completion](features_dcd), the [runnables](features_runnables), the CE project format strongly rely on it. + +The _libman_ links the library files (_*.lib_ or _*.a_) to their D sources and are represented with a simple **alias** that is used in different part of the software. +For example, in a project, you don't need anymore to specify the **-I** path nor its matching library file name. +Coedit handles the task automatically (see later in the project configuration widget, [general options][lnk_widg_prjconf_gen]). + +![](img/library_manager.png) + +#### Import analysis + +Since version 3, the _libman_ also contains a database that links each item to a list of module. +This is used to automatically detect a dependency from a simple import declaration. +This features is only used for the CE project format and the [runnables](features_runnables) modules. + +#### Toolbar + +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/book/book_add.png): Adds a library item, by default its fields are initialized with _n/a_. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/book/book_delete.png): Removes the selected item. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/arrow/arrow_up.png) **/** ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/arrow/arrow_down.png): Changes selected entry position. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/book/book_link.png): If the current project is a static library then the _libman_ will use its parameters to create an entry. This avoids to browse in the dialogs. Note that sometimes the sources root folder has to be adjusted. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/book/book_open.png): If the selected item defines a _project_ then closes current project and opens the one matching to the entry. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/other/dub_small.png): Allows to fetch the master version of a [DUB registry item](http://code.dlang.org/). See the last section. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/book/book.png): enable or disable the selected entry. This is mainly useful to test new DMD versions since the libraries often have to be recompiled from a version to another. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/book/book_edit.png): edit the item alias. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/folder/folder_brick.png): select the library file. In some rare case, this field can be omitted (for example if the library file is set in the _sc.ini_). +This can be skipped if the library is only a small orphan _d_ source that's not been compiled as a static library or if the entry is only used for the [DCD](features_dcd) completion. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/other/bricks.png): select a folder that contains several libraries files or several orphans modules. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/folder/folder_add.png): select the sources root folder. (the one commonly named 'import'). +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/other/script_bricks.png): set the project file that matches to the selected item. + +#### Register online DUB packages + +When the toolbar button that displays DUB logo is clicked, a dialog is displayed. It used to select an online package that will be downloaded, compiled and automatically installed in the _libman_ + +![img/dub_register_package] + +The text field is used to select the name of the package to install. + +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/book/arrow_update.png): Update the list of the online packages. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/other/tag_purple.png): By the default the master version of the package is installed. When the tag button is down Coedit rather installs the package from its latest tag. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/other/accept.png): Closes the dialog and start downloading before installing. +- ![](https://raw.githubusercontent.com/BBasile/Coedit/master/icons/other/cancel.png): Cancels and does nothing. \ No newline at end of file