Implemented setTaskPriority() and getTaskPriority() in Task HAL API Removed all other unimplemented functions in HAL and removed spawnTask() Replaced instances of pthread_t* with TASK typedef Removed unused HAL error constants and removed commented-out classes and functions in wpilibj's HALLibrary Changed Task class API to match the construction semantics of a std::thread Change-Id: I3bc951a3da90d24c5589fae4d1ca2bb60225c873
Purpose
NetworkTables is a HashTable synchronized across the network. It provides a simple interface for sharing numbers, booleans, strings and homogeneous arrays of those components between the robot, driverstation, co-processor and any other computer teams wish to have provide or consume data.
Contributing
- Checkout
- Edit
- Commit
- Push using
git push origin HEAD:refs/for/master - Wait for code review, checking for comments.
Editing
You can always use any text editor and then build with Maven. Eclipse support works well with the m2eclipse plugin. Individual components may have there own project files.
Building with Maven
Currently, Maven only builds NetworkTables Java and C++. The various table viewer projects have not been migrated yet.
There are multiple build targets that NetworkTables supports. To build it, it is assumed that the toolchains have been setup as described in the WPILib development documentation. In both Java and C++ there are three build targets, Desktop, Azalea and Athena. For Java the Athena and Desktop builds are identical. Building the Desktop versions will run UnitTests on the platform.
cdinto the root directory if you want to build both languages. Otherwise,cdinto the language you want to build.- Run
mvn installif you want to build and install everything. - That's it. You can build only for a specific platform by using
Maven profiles. For example, just add
-Pdesktopwhen developing to run the unit tests without compiling for other platforms.