Difference between revisions of "Documentation/Nightly/Developers"

From Slicer Wiki
Jump to: navigation, search
m
Tag: 2017 source edit
(39 intermediate revisions by 6 users not shown)
Line 1: Line 1:
 +
<noinclude>{{documentation/versioncheck}}</noinclude>
 
__NOTOC__
 
__NOTOC__
 
+
{| border="0" align="center" width="98%" cellspacing="7" cellpadding="2" valign="top"
 
 
{| border="0" align="center" width="98%" valign="top" cellspacing="7" cellpadding="2"
 
 
|-
 
|-
 
|<span style="color: #555555; font-size: 18px; font-weight: bold;">New Developers</span>:&nbsp;&nbsp;&nbsp;&nbsp;<big><big>Welcome ! Check these '''[[{{FULLPAGENAME}}/StartHere|instructions]]''' !</big></big>
 
|<span style="color: #555555; font-size: 18px; font-weight: bold;">New Developers</span>:&nbsp;&nbsp;&nbsp;&nbsp;<big><big>Welcome ! Check these '''[[{{FULLPAGENAME}}/StartHere|instructions]]''' !</big></big>
 
|}
 
|}
  
{| border="0" align="center" width="98%" valign="top" cellspacing="7" cellpadding="2"
+
{| border="0" align="center" width="98%" cellspacing="7" cellpadding="2" valign="top"
 
|-
 
|-
! width="33%"|
+
! width="33%" |
 
! |
 
! |
! width="33%"|
+
! width="33%" |
 
! |
 
! |
! width="33%"|
+
! width="33%" |
 
|-  
 
|-  
|valign="top"|
+
| valign="top" |
 
----
 
----
 
<span style="color: #555555; font-size: 18px; font-weight: bold;">Getting involved</span>
 
<span style="color: #555555; font-size: 18px; font-weight: bold;">Getting involved</span>
 
----
 
----
  
* [[Documentation/{{documentation/version}}/Developers/StartHere|Start here]]
+
[[Documentation/{{documentation/version}}/Developers/StartHere|Start here]]
: New community member checklist
+
 
 +
:New community member checklist
  
* [[{{FULLPAGENAME}}/Meetings|Developer meetings]]
+
[[{{FULLPAGENAME}}/Meetings|Developer meetings]]
: It is open to everyone, feel free to join.
 
  
* [http://massmail.bwh.harvard.edu/mailman/listinfo/slicer-devel Developers mailing list] / [http://massmail.bwh.harvard.edu/mailman/listinfo/slicer-devel Sign-up] / [http://slicer-devel.65872.n3.nabble.com/ Browse archives]
+
:It is open to everyone, feel free to join.
 +
 
 +
[https://discourse.slicer.org Discussion Forum]
 +
 
 +
:The most effective way to get help from the community
 +
<!--
 +
[http://slicer-devel.65872.n3.nabble.com/ Search developers mailing list] / [http://massmail.spl.harvard.edu/mailman/listinfo/slicer-devel Sign-up]
 
: Intended for discussion of programming related questions
 
: Intended for discussion of programming related questions
 +
-->
 +
 +
[[Documentation/{{documentation/version}}/Developers/FAQ|FAQ]]
 +
 +
:Set of common development questions/answers
  
* [[Documentation/{{documentation/version}}/Developers/FAQ|FAQ]]
 
: Set of common development questions/answers
 
 
----
 
----
 
<span style="color: #555555; font-size: 18px; font-weight: bold;">Resources</span>
 
<span style="color: #555555; font-size: 18px; font-weight: bold;">Resources</span>
 
----
 
----
* [[Roadmap|Roadmap]]{{new}}
+
[[Roadmap|Roadmap]]{{updated}}
: What's next ? What's the plan ?
+
 
 +
:What's next ? What's the plan ?
 +
 
 +
[[Documentation/Labs|Labs]] {{new}}
 +
 
 +
:Keep track of on-going experiments.
 +
 
 +
[http://apidocs.slicer.org/master/annotated.html Doxygen]
 +
 
 +
:Source code API documentation.
 +
 
 +
Source code repository
 +
 
 +
:[https://github.com/Slicer/Slicer Github] or [http://viewvc.slicer.org/viewvc.cgi/Slicer4/trunk SVN]
 +
 
 +
CDash Quality Dashboard: [http://slicer.cdash.org/index.php?project=Slicer4 SlicerStable], [http://slicer.cdash.org/index.php?project=SlicerPreview SlicerPreview]
 +
 
 +
:Nightly, continuous and experimental dashboards. - <small>[[{{FULLPAGENAME}}/Tutorials/DashboardSetup|Setup a dashboard]]</small>
  
* Source code repository
+
[https://issues.slicer.org Bug tracker] / [https://issues.slicer.org/signup_page.php Register] / [[Documentation/{{documentation/version}}/Report_a_problem|Report a problem]] /  [[Documentation/{{documentation/version}}/Developers/Tutorials/ContributePatch|Contribute a patch]]
: [https://github.com/Slicer/Slicer Github] or [http://viewvc.slicer.org/viewvc.cgi/Slicer4/trunk SVN]
 
  
* [http://slicer.cdash.org/index.php?project=Slicer4 CDash Quality Dashboard] / [[{{FULLPAGENAME}}/Tutorials/DashboardSetup|Setup a dashboard]]
+
:Web-based bug tracking system - <small>[[Documentation/{{documentation/version}}/Developers/BugTrackerConfiguration|Configuration]]</small>
: Nightly, continuous and experimental dashboards.
 
  
* [http://na-mic.org/Mantis Bug tracker] / [http://na-mic.org/Mantis/signup_page.php Register] / [[Documentation/{{documentation/version}}/Report_a_problem|Report a problem]] / [[Documentation/{{documentation/version}}/Developers/Tutorials/ContributePatch|Contribute a patch]] / [[Documentation/{{documentation/version}}/MantisConfiguration|Mantis Configuration]]
+
[[{{FULLPAGENAME}}/Style Guide|Slicer Style Guidelines]]
: Web-based bug tracking system
 
  
* [http://slicer.org/doc/html/classes.html Doxygen]
+
:Consistency and Readability for a manageable code base
: Source code API documentation.
 
  
* [[{{FULLPAGENAME}}/Style Guide|Slicer Style Guidelines]]
+
[[Documentation/{{documentation/version}}/ScriptRepository|Script repository]]
: Consistency and Readability for a manageable code base
 
  
* [[Slicer4:Developers|Developer Projects]]
+
:Collection of python scripts manipulating various Slicer components.
: Pages for the developer projects.
 
  
* [[Documentation/Labs|Labs]] {{new}}
+
[[Release Details|Change logs and release details]]
: Keep track of on-going experiments.
 
  
* [[Release Details|Change logs and release details]]
+
:Informations about Slicer releases
: Informations about Slicer releases
 
  
 +
[[Resources]]
  
|bgcolor="#CCCCCC"|
+
:List Slicer resources and who to contact in case of problem.
|valign="top"|
+
 
 +
| bgcolor="#CCCCCC" |
 +
| valign="top" |
 
----
 
----
 
<span style="color: #555555; font-size: 18px; font-weight: bold;">Build instructions</span>
 
<span style="color: #555555; font-size: 18px; font-weight: bold;">Build instructions</span>
 
----
 
----
  
* [[Documentation/{{documentation/version}}/Developers/Build Instructions|Build Slicer application]]
+
[[Documentation/{{documentation/version}}/Developers/Tutorials/BuildTestPackageDistributeExtensions|Create Slicer extensions]] {{updated}}
: Compiling and installing Slicer from source.
 
  
* [[Documentation/{{documentation/version}}/Developers/Build Module|Build Module]]
+
:Build, test, package and distribute extensions
: Compiling slicer modules outside of the slicer source tree.
 
  
* [[Documentation/{{documentation/version}}/Developers/Tutorials/BuildTestPackageDistributeExtensions|Create Slicer extensions]]
+
[[Documentation/{{documentation/version}}/Developers/Build Instructions|Build Slicer application]]
: Build, test, package and distribute extensions
+
 
 +
:Compiling and installing Slicer from source.
 +
 
 +
[[Documentation/{{documentation/version}}/Developers/Build Module|Build Module]]
 +
 
 +
:Compiling slicer modules outside of the slicer source tree.
  
 +
----
 +
<span style="color: #555555; font-size: 18px; font-weight: bold;">How-tos</span>&nbsp;&nbsp;
 +
----
 +
{{:{{FULLPAGENAME}}/Tutorials}}
 +
----
 +
<span style="color: #555555; font-size: 18px; font-weight: bold;">Quick links</span>&nbsp;&nbsp;
 +
----
 +
{{:{{FULLPAGENAME}}/Quicklinks}}
 +
 +
| bgcolor="#CCCCCC" |
 +
| valign="top" |
 
----
 
----
 
<span style="color: #555555; font-size: 18px; font-weight: bold;">Design & Implementation</span>
 
<span style="color: #555555; font-size: 18px; font-weight: bold;">Design & Implementation</span>
 
----
 
----
  
* [[{{FULLPAGENAME}}/Modules | Modules]]
+
[[{{FULLPAGENAME}}/Modules | Modules]]
: Comparison between the different supported module types
 
  
* Internals
+
:Comparison between the different supported module types
** [[{{FULLPAGENAME}}/MRML | Data Model / MRML]] - Objects and their organization. MRML Library provides API for managing medical image data type
 
** [[{{FULLPAGENAME}}/Logics | Logics]] - Details the role of MRML/Slicer/Application/Modules logics and Displayable managers
 
** [[{{FULLPAGENAME}}/Layouts | Layouts]] - How to control the layout of the views
 
** [[{{FULLPAGENAME}}/IO | IO Mechanism]] - How to read or write nodes from file
 
  
* [[{{FULLPAGENAME}}/Python scripting | Python scripting]]
+
[[{{FULLPAGENAME}}/MRML | Data Model / MRML]]
: Presents the underlying infrastructure.
 
  
* [[{{FULLPAGENAME}}/Charts | Charts]]
+
:Objects and their organization. MRML Library provides API for managing medical image data type
: Description of the Charting architecture.
 
  
* [[{{FULLPAGENAME}}/Build system | Build system]] {{updated}}
+
[[{{FULLPAGENAME}}/Logics | Logics]]
: Details how Slicer is built and packaged.
 
  
* [[{{FULLPAGENAME}}/QtTesting | QtTesting]]
+
:Details the role of MRML/Slicer/Application/Modules logics and Displayable managers
: Testing framework to test Slicer application. It complements unit tests.
 
  
|bgcolor="#CCCCCC"|
+
[[{{FULLPAGENAME}}/Layouts | Layouts]] {{updated}}
|valign="top"|
+
 
----
+
:How to control the layout of the views
{{:{{FULLPAGENAME}}/Tutorials}}
+
 
 +
[[{{FULLPAGENAME}}/Slice Orientation Presets | Slice Orientation Presets]] {{new}}
 +
 
 +
:How to manage slice orientation presets
 +
 
 +
[[{{FULLPAGENAME}}/Slicelets | Slicelets]]
 +
 
 +
:Create simple standalone applications (slicelets)
 +
 
 +
[[{{FULLPAGENAME}}/IO | IO Mechanism]]
 +
 
 +
:How to read or write nodes from file
 +
 
 +
[[{{FULLPAGENAME}}/Python scripting | Python scripting]]
 +
 
 +
:Presents the underlying infrastructure.
 +
 
 +
[[{{FULLPAGENAME}}/Charts | Charts]]
 +
 
 +
:Description of the Charting (jqPlot) architecture.
 +
 
 +
[[{{FULLPAGENAME}}/Plots | Plots]] {{new}}
 +
 
 +
:Description of the Plotting (VTK) architecture.
 +
 
 +
[[{{FULLPAGENAME}}/CompressedVideo | Compressed Video]] {{new}}
 +
 
 +
:Description of the compressed video architecture.
 +
 
 +
[[{{FULLPAGENAME}}/DirectoryStructure | Directory Structure]]
 +
 
 +
:Files location in the build and install tree.
 +
 
 +
[[{{FULLPAGENAME}}/QtPlugins|Qt Plugins]]
 +
 
 +
:How to build and load Qt plugins.
 +
 
 +
[[{{FULLPAGENAME}}/Build system | Build system / Release process / Factory description]]
 +
 
 +
:Details how Slicer is built and packaged.
 +
 
 +
[[{{FULLPAGENAME}}/QtTesting | QtTesting]]
 +
 
 +
:Testing framework to test Slicer application. It complements unit tests.
  
 
|}
 
|}
  
<hr>
+
<hr />
  
  
 
[[{{collaborator|logo|slicer4}}|x300px|center]]
 
[[{{collaborator|logo|slicer4}}|x300px|center]]

Revision as of 19:52, 14 November 2019

Home < Documentation < Nightly < Developers


For the latest Slicer documentation, visit the read-the-docs.


New Developers:    Welcome ! Check these instructions !

Getting involved


Start here

New community member checklist

Developer meetings

It is open to everyone, feel free to join.

Discussion Forum

The most effective way to get help from the community

FAQ

Set of common development questions/answers

Resources


Roadmap  UPDATED

What's next ? What's the plan ?

Labs   NEW

Keep track of on-going experiments.

Doxygen

Source code API documentation.

Source code repository

Github or SVN

CDash Quality Dashboard: SlicerStable, SlicerPreview

Nightly, continuous and experimental dashboards. - Setup a dashboard

Bug tracker / Register / Report a problem / Contribute a patch

Web-based bug tracking system - Configuration

Slicer Style Guidelines

Consistency and Readability for a manageable code base

Script repository

Collection of python scripts manipulating various Slicer components.

Change logs and release details

Informations about Slicer releases

Resources

List Slicer resources and who to contact in case of problem.

Build instructions


Create Slicer extensions   UPDATED

Build, test, package and distribute extensions

Build Slicer application

Compiling and installing Slicer from source.

Build Module

Compiling slicer modules outside of the slicer source tree.

How-tos  


Migration Guide

How to update Slicer extension code following breaking changes in Slicer or dependent toolkits (VTK, ITK, Qt, ...)

Source code How-tos

How to checkout the source and contribute patches

Module How-tos

How to create or build modules, how to add or update remote modules

Testing How-tos

How to write tests and manage testing data

Documentation How-tos

How to document module or extension

Extension How-tos

How to contribute, build or package extensions

Misc How-tos

How to setup QtCreator, setup dashboard, work with QtDesigner, port modules


Debugging instructions: https://slicer.readthedocs.io/en/latest/developer_guide/debugging/index.html


Quick links  


Stable Dashboard
Preview Dashboard
Source
C++ API

Contribute
Style Guide
Issue Tracker

WikiCheatSheet, Wiki Editing Guide

Mailing list archives
FAQ



Design & Implementation


Modules

Comparison between the different supported module types

Data Model / MRML

Objects and their organization. MRML Library provides API for managing medical image data type

Logics

Details the role of MRML/Slicer/Application/Modules logics and Displayable managers

Layouts   UPDATED

How to control the layout of the views

Slice Orientation Presets   NEW

How to manage slice orientation presets

Slicelets

Create simple standalone applications (slicelets)

IO Mechanism

How to read or write nodes from file

Python scripting

Presents the underlying infrastructure.

Charts

Description of the Charting (jqPlot) architecture.

Plots   NEW

Description of the Plotting (VTK) architecture.

Compressed Video   NEW

Description of the compressed video architecture.

Directory Structure

Files location in the build and install tree.

Qt Plugins

How to build and load Qt plugins.

Build system / Release process / Factory description

Details how Slicer is built and packaged.

QtTesting

Testing framework to test Slicer application. It complements unit tests.


Slicer4Announcement-HiRes.png