Difference between revisions of "Documentation/Nightly/Developers"

From Slicer Wiki
Jump to: navigation, search
m
(19 intermediate revisions by 4 users not shown)
Line 1: Line 1:
 
<noinclude>{{documentation/versioncheck}}</noinclude>
 
<noinclude>{{documentation/versioncheck}}</noinclude>
 
__NOTOC__
 
__NOTOC__
 
 
 
{| border="0" align="center" width="98%" valign="top" cellspacing="7" cellpadding="2"
 
{| border="0" align="center" width="98%" valign="top" cellspacing="7" cellpadding="2"
 
|-
 
|-
Line 27: Line 25:
 
: It is open to everyone, feel free to join.
 
: 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]
+
[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]]
 
[[Documentation/{{documentation/version}}/Developers/FAQ|FAQ]]
Line 37: Line 39:
 
[[Roadmap|Roadmap]]{{updated}}
 
[[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
 
Source code repository
 
: [https://github.com/Slicer/Slicer Github] or [http://viewvc.slicer.org/viewvc.cgi/Slicer4/trunk SVN]
 
: [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]]
+
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.
+
: Nightly, continuous and experimental dashboards. - <small>[[{{FULLPAGENAME}}/Tutorials/DashboardSetup|Setup a dashboard]]</small>
  
 
[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]]
 
[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]]
 
: Web-based bug tracking system - <small>[[Documentation/{{documentation/version}}/Developers/BugTrackerConfiguration|Configuration]]</small>
 
: Web-based bug tracking system - <small>[[Documentation/{{documentation/version}}/Developers/BugTrackerConfiguration|Configuration]]</small>
 
[http://slicer.org/doc/html/classes.html Doxygen]
 
: Source code API documentation.
 
  
 
[[{{FULLPAGENAME}}/Style Guide|Slicer Style Guidelines]]
 
[[{{FULLPAGENAME}}/Style Guide|Slicer Style Guidelines]]
 
: Consistency and Readability for a manageable code base
 
: Consistency and Readability for a manageable code base
 
[[Documentation/Labs|Labs]] {{new}}
 
: Keep track of on-going experiments.
 
  
 
[[Release Details|Change logs and release details]]
 
[[Release Details|Change logs and release details]]
Line 78: Line 80:
 
: Compiling slicer modules outside of the slicer source tree.
 
: 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|<i class="fa fa-link fa-lg" aria-hidden="true"></i>]]
 +
----
 +
{{:{{FULLPAGENAME}}/Tutorials}}
 +
----
 +
<span style="color: #555555; font-size: 18px; font-weight: bold;">Quick links</span>&nbsp;&nbsp;[[{{FULLPAGENAME}}/Quicklinks|<i class="fa fa-link fa-lg" aria-hidden="true"></i>]]
 +
----
 +
{{:{{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>
Line 91: Line 104:
 
: Details the role of MRML/Slicer/Application/Modules logics and Displayable managers
 
: Details the role of MRML/Slicer/Application/Modules logics and Displayable managers
  
[[{{FULLPAGENAME}}/Layouts | Layouts]]
+
[[{{FULLPAGENAME}}/Layouts | Layouts]] {{updated}}
 
: How to control the layout of the views
 
: How to control the layout of the views
 +
 +
[[{{FULLPAGENAME}}/Slice Orientation Presets | Slice Orientation Presets]] {{new}}
 +
: How to manage slice orientation presets
  
 
[[{{FULLPAGENAME}}/Slicelets | Slicelets]]
 
[[{{FULLPAGENAME}}/Slicelets | Slicelets]]
Line 104: Line 120:
  
 
[[{{FULLPAGENAME}}/Charts | Charts]]
 
[[{{FULLPAGENAME}}/Charts | Charts]]
: Description of the Charting architecture.
+
: Description of the Charting (jqPlot) architecture.
 +
 
 +
[[{{FULLPAGENAME}}/Plots | Plots]] {{new}}
 +
: Description of the Plotting (VTK) architecture.
  
 
[[{{FULLPAGENAME}}/DirectoryStructure | Directory Structure]]
 
[[{{FULLPAGENAME}}/DirectoryStructure | Directory Structure]]
Line 117: Line 136:
 
[[{{FULLPAGENAME}}/QtTesting | QtTesting]]
 
[[{{FULLPAGENAME}}/QtTesting | QtTesting]]
 
: Testing framework to test Slicer application. It complements unit tests.
 
: Testing framework to test Slicer application. It complements unit tests.
 
|bgcolor="#CCCCCC"|
 
|valign="top"|
 
----
 
{{:{{FULLPAGENAME}}/Tutorials}}
 
  
 
|}
 
|}

Revision as of 20:26, 16 February 2018

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

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.

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