zephyr/doc
David B. Kinder ac74d8b652 license: Replace Apache boilerplate with SPDX tag
Replace the existing Apache 2.0 boilerplate header with an SPDX tag
throughout the zephyr code tree. This patch was generated via a
script run over the master branch.

Also updated doc/porting/application.rst that had a dependency on
line numbers in a literal include.

Manually updated subsys/logging/sys_log.c that had a malformed
header in the original file.  Also cleanup several cases that already
had a SPDX tag and we either got a duplicate or missed updating.

Jira: ZEP-1457

Change-Id: I6131a1d4ee0e58f5b938300c2d2fc77d2e69572c
Signed-off-by: David B. Kinder <david.b.kinder@intel.com>
Signed-off-by: Kumar Gala <kumar.gala@linaro.org>
2017-01-19 03:50:58 +00:00
..
api doc: application porting guide to the unified kernel 2017-01-16 18:13:03 -05:00
application build: abstract emulation and replace qemu goal with run 2017-01-10 20:20:47 +00:00
contribute doc: Remove contributor documentation moved to wiki 2016-08-04 22:01:10 +00:00
crypto doc: Terminology--Replace 'platform' with 'board' 2016-08-12 22:57:24 +00:00
drivers doc: remove device_sync_call documentation 2016-12-21 13:53:12 +00:00
getting_started build: abstract emulation and replace qemu goal with run 2017-01-10 20:20:47 +00:00
introduction boards: prepare for integration of board documentation 2017-01-10 02:45:54 +00:00
kernel doc: application porting guide to the unified kernel 2017-01-16 18:13:03 -05:00
porting license: Replace Apache boilerplate with SPDX tag 2017-01-19 03:50:58 +00:00
reference/kconfig doc: restructure application primer 2016-12-24 01:53:17 +00:00
scripts license: Replace Apache boilerplate with SPDX tag 2017-01-19 03:50:58 +00:00
subsystems sensor: remove sensor value type 2017-01-15 01:09:33 +00:00
templates boards: prepare for integration of board documentation 2017-01-10 02:45:54 +00:00
themes/zephyr doc: Change conf.py and index.rst to fix the copyright and license. 2016-02-05 20:24:34 -05:00
conf.py doc: support official website theme 2017-01-05 12:26:49 +00:00
doxygen.config kernel: doc: Add deprecation notice to legacy.h 2017-01-16 18:13:03 -05:00
index.rst doc: move context back to doc/, fix broken links 2017-01-16 18:05:06 -05:00
LICENSING.rst ksdk: mcux: Rename ksdk to mcux 2017-01-12 09:46:26 -06:00
Makefile doc: make build process quiet 2017-01-16 18:13:03 -05:00
README.rst doc: update doc building README instructions 2017-01-16 23:58:08 +00:00
release-notes.rst doc: application porting guide to the unified kernel 2017-01-16 18:13:03 -05:00

:orphan:

Welcome to Zephyr Kernel
########################

.. This document is in Restructured Text Format.
   Find more information regarding the ReST markup in the
   `ReST documentation`_.
   This is a comment that won't show up in formatted output

Welcome to the Zephyr Project.

Thank you for your interest in the Zephyr Project. These instructions are
designed to walk you through generating the Zephyr Project's documentation.

Documentation Notes
*******************

Zephyr Project content is written using the reStructuredText markup language
(.rst file extension) with Sphinx extensions, and processed using sphinx to
create a formatted standalone website. Developers can view this content either
in its raw form as .rst markup files, or you can generate the HTML content and view it
with a web browser directly on your workstations drive. This same .rst
content is also fed into the Zephyr Project'ns public website documentation area
(with a different theme applied).

You can read details about reStructuredText and about Sphinx extensions from
their respective websites.

The project's documentation currently comprises the following items:

* ReStructuredText source files used to generate documentation found at
  https://zephyrproject.org/doc website. Most of the reStructuredText sources
  are found in the ``/doc`` directory, but there are others stored within the
  code source tree near their specific component (such as ``/samples`` and
  ``/boards``)

* Doxygen-generated material used to create all API-specific documents
  also found at https://zephyrproject.org/doc

* Script-generated material for kernel configuration options based on kconfig
  files found in the source code tree

* Additional material on https://wiki.zephyrproject.org

The reStructuredText files are processed by the Sphinx documentation system,
and make use of the breathe extension for including the doxygen-generated API
material.  Additional tools are required to generate the
documentation locally, as described in the following sections.

Installing the documentation processors
***************************************

Our documentation processing has been tested to run with:

* Doxygen version 1.8.10 (and 1.8.11)
* Sphinx version 1.4.4 (but not with 1.5.1)
* Breathe version 4.4.0
* docutils version 0.12 (0.13 has issues with Sphinx 1.4.4)

Begin by cloning a copy of the git repository for the zephyr project and
setting up your development environment as described in :ref:`getting_started`
or specifically for Ubuntu in :ref:`installation_linux`.  (Be sure to
export the environment variables ``ZEPHYR_GCC_VARIANT`` and
``ZEPHYR_SDK_INSTALL_DIR`` as documented there.)

Here are a set of commands to install the documentation generations tools on
Ubuntu:


.. code-block:: bash

   $ sudo apt-get install python-pip
   $ pip install --upgrade pip
   $ sudo apt-get install doxygen
   $ pip install sphinx==1.4.4
   $ sudo -H pip install breathe
   $ sudo -H pip install sphinx-rtd-theme

There is a known issue that causes docutils version 0.13 to fail with sphinx
1.4.4.  Verify the version of docutils using:

.. code-block:: bash

   $ pip show docutils

If this shows you've got version 0.13 of docutils installed, you can install
the working version of docutils with:

.. code-block:: bash

   $ sudo -H pip install docutils==0.12


Running the Documentation Generators
************************************

The ``/doc`` directory in your cloned copy of zephyr project git repo has all the
.rst source files, extra tools, and Makefile for generating a local copy of
the Zephyr project's technical documentation.  Assuming the local Zephyr
project copy is ``~/zephyr``, here are the commands to generate the html
content locally:

.. code-block:: bash

   $ cd ~/zephyr
   $ source zephyr-env.sh
   $ make htmldocs

The html output will be in ``~/zephyr/doc/_build/html/index.html``


.. _ReST documentation: http://sphinx-doc.org/rest.html