| 
									
										
										
										
											2016-01-01 20:51:48 +02:00
										 |  |  | ..  Copyright 2014-2016 Ivan Kravets <me@ikravets.com>
 | 
					
						
							| 
									
										
										
										
											2015-11-18 17:33:46 +02:00
										 |  |  |     Licensed under the Apache License, Version 2.0 (the "License");
 | 
					
						
							|  |  |  |     you may not use this file except in compliance with the License.
 | 
					
						
							|  |  |  |     You may obtain a copy of the License at
 | 
					
						
							|  |  |  |        http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							|  |  |  |     Unless required by applicable law or agreed to in writing, software
 | 
					
						
							|  |  |  |     distributed under the License is distributed on an "AS IS" BASIS,
 | 
					
						
							|  |  |  |     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
					
						
							|  |  |  |     See the License for the specific language governing permissions and
 | 
					
						
							|  |  |  |     limitations under the License.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-07 19:38:00 +03:00
										 |  |  | .. _library_creating:
 | 
					
						
							| 
									
										
										
										
											2014-10-18 20:03:38 +03:00
										 |  |  | .. |PIOAPICR| replace:: *PlatformIO Library Registry Crawler*
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-07 15:09:32 +03:00
										 |  |  | Creating Library
 | 
					
						
							|  |  |  | ================
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-07 18:14:33 +03:00
										 |  |  | *PlatformIO* :ref:`librarymanager` doesn't have any requirements to a library
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | source code structure. The only one requirement is library's manifest file -
 | 
					
						
							|  |  |  | :ref:`library_config`. It can be located inside your library or in the another
 | 
					
						
							|  |  |  | location where |PIOAPICR| will have *HTTP* access.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. contents::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Source Code Location
 | 
					
						
							|  |  |  | --------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | There are a several ways how to share your library with the whole world
 | 
					
						
							| 
									
										
										
										
											2015-03-25 12:15:17 +02:00
										 |  |  | (see `examples <https://github.com/platformio/platformio-libmirror/tree/master/configs>`_).
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-09 23:16:36 +03:00
										 |  |  | You can hold a lot of libraries (split into separated folders) inside one of
 | 
					
						
							|  |  |  | the repository/archive. In this case please use :ref:`libjson_include`
 | 
					
						
							| 
									
										
										
										
											2014-09-07 18:14:33 +03:00
										 |  |  | field to specify the relative path to your library's source code.
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:55:48 +03:00
										 |  |  | At GitHub
 | 
					
						
							|  |  |  | ^^^^^^^^^
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | **Recommended**
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-07 18:14:33 +03:00
										 |  |  | If a library source code is located at `GitHub <https://github.com>`_, then
 | 
					
						
							|  |  |  | you **need to specify** only these fields in the :ref:`library_config`:
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | * :ref:`libjson_name`
 | 
					
						
							|  |  |  | * :ref:`libjson_keywords`
 | 
					
						
							|  |  |  | * :ref:`libjson_description`
 | 
					
						
							|  |  |  | * :ref:`libjson_repository`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | |PIOAPICR| will populate the rest fields, like :ref:`libjson_version` or
 | 
					
						
							| 
									
										
										
										
											2014-10-22 23:52:17 +03:00
										 |  |  | :ref:`libjson_authors` with an actual information from *GitHub*.
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | Example:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: javascript
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     {
 | 
					
						
							| 
									
										
										
										
											2014-10-27 22:47:53 +02:00
										 |  |  |         "name": "IRremote",
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  |         "keywords": "infrared, ir, remote",
 | 
					
						
							|  |  |  |         "description": "Send and receive infrared signals with multiple protocols",
 | 
					
						
							|  |  |  |         "repository":
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             "type": "git",
 | 
					
						
							|  |  |  |             "url": "https://github.com/shirriff/Arduino-IRremote.git"
 | 
					
						
							| 
									
										
										
										
											2014-12-03 14:56:24 +02:00
										 |  |  |         },
 | 
					
						
							|  |  |  |         "frameworks": "arduino",
 | 
					
						
							|  |  |  |         "platforms": "atmelavr"
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:55:48 +03:00
										 |  |  | Under CVS (SVN/GIT)
 | 
					
						
							|  |  |  | ^^^^^^^^^^^^^^^^^^^
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-07 18:14:33 +03:00
										 |  |  | |PIOAPICR| can operate with a library source code that is under *CVS* control.
 | 
					
						
							|  |  |  | The list of **required** fields in the :ref:`library_config` will look like:
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | * :ref:`libjson_name`
 | 
					
						
							|  |  |  | * :ref:`libjson_keywords`
 | 
					
						
							|  |  |  | * :ref:`libjson_description`
 | 
					
						
							| 
									
										
										
										
											2014-10-22 23:52:17 +03:00
										 |  |  | * :ref:`libjson_authors`
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | * :ref:`libjson_repository`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Example:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: javascript
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     {
 | 
					
						
							| 
									
										
										
										
											2014-10-27 22:47:53 +02:00
										 |  |  |         "name": "XBee",
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  |         "keywords": "xbee, protocol, radio",
 | 
					
						
							|  |  |  |         "description": "Arduino library for communicating with XBees in API mode",
 | 
					
						
							| 
									
										
										
										
											2014-10-27 22:47:53 +02:00
										 |  |  |         "authors":
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  |         {
 | 
					
						
							|  |  |  |             "name": "Andrew Rapp",
 | 
					
						
							|  |  |  |             "email": "andrew.rapp@gmail.com",
 | 
					
						
							|  |  |  |             "url": "https://code.google.com/u/andrew.rapp@gmail.com/"
 | 
					
						
							|  |  |  |         },
 | 
					
						
							|  |  |  |         "repository":
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             "type": "git",
 | 
					
						
							|  |  |  |             "url": "https://code.google.com/p/xbee-arduino/"
 | 
					
						
							| 
									
										
										
										
											2014-12-03 14:56:24 +02:00
										 |  |  |         },
 | 
					
						
							|  |  |  |         "frameworks": "arduino",
 | 
					
						
							|  |  |  |         "platforms": "atmelavr"
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-08 15:37:04 +03:00
										 |  |  | Self-hosted
 | 
					
						
							|  |  |  | ^^^^^^^^^^^
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-07 18:14:33 +03:00
										 |  |  | You can manually archive (*Zip, Tar.Gz*) your library source code and host it
 | 
					
						
							|  |  |  | in the *Internet*. Then you should specify the additional fields,
 | 
					
						
							|  |  |  | like :ref:`libjson_version` and :ref:`libjson_downloadurl`. The final list
 | 
					
						
							|  |  |  | of **required** fields in the :ref:`library_config` will look like:
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | * :ref:`libjson_name`
 | 
					
						
							|  |  |  | * :ref:`libjson_keywords`
 | 
					
						
							|  |  |  | * :ref:`libjson_description`
 | 
					
						
							| 
									
										
										
										
											2014-10-22 23:52:17 +03:00
										 |  |  | * :ref:`libjson_authors`
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | * :ref:`libjson_version`
 | 
					
						
							|  |  |  | * :ref:`libjson_downloadurl`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: javascript
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     {
 | 
					
						
							| 
									
										
										
										
											2014-10-27 22:47:53 +02:00
										 |  |  |         "name": "OneWire",
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  |         "keywords": "onewire, 1-wire, bus, sensor, temperature, ibutton",
 | 
					
						
							|  |  |  |         "description": "Control devices (from Dallas Semiconductor) that use the One Wire protocol (DS18S20, DS18B20, DS2408 and etc)",
 | 
					
						
							| 
									
										
										
										
											2014-10-27 22:47:53 +02:00
										 |  |  |         "authors":
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  |         {
 | 
					
						
							|  |  |  |             "name": "Paul Stoffregen",
 | 
					
						
							|  |  |  |             "url": "http://www.pjrc.com/teensy/td_libs_OneWire.html"
 | 
					
						
							|  |  |  |         },
 | 
					
						
							|  |  |  |         "version": "2.2",
 | 
					
						
							|  |  |  |         "downloadUrl": "http://www.pjrc.com/teensy/arduino_libraries/OneWire.zip",
 | 
					
						
							| 
									
										
										
										
											2014-12-03 14:56:24 +02:00
										 |  |  |         "include": "OneWire",
 | 
					
						
							|  |  |  |         "frameworks": "arduino",
 | 
					
						
							|  |  |  |         "platforms": "atmelavr"
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Register
 | 
					
						
							|  |  |  | --------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-07 18:14:33 +03:00
										 |  |  | The registration requirements:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * A library must adhere to the :ref:`library_config` specification.
 | 
					
						
							|  |  |  | * There must be public *HTTP* access to the library :ref:`library_config` file.
 | 
					
						
							| 
									
										
										
										
											2014-09-06 23:51:28 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | Now, you can :ref:`register <cmd_lib_register>` your library and allow others
 | 
					
						
							|  |  |  | to :ref:`install <cmd_lib_install>` it.
 | 
					
						
							| 
									
										
										
										
											2015-04-27 18:27:26 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-30 01:41:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. _library_creating_examples:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Examples
 | 
					
						
							|  |  |  | --------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-12 21:32:13 +02:00
										 |  |  | * `GitHub + fixed release <http://platformio.org/lib/show/552/ACNoblex>`_
 | 
					
						
							|  |  |  | * `Dependencies by author and framework <http://platformio.org/lib/show/3/PID-AutoTune>`_
 | 
					
						
							| 
									
										
										
										
											2015-12-30 01:41:08 +02:00
										 |  |  | * `Multiple libraries in the one repository <https://github.com/jrowberg/i2cdevlib/tree/master/Arduino>`_
 |