cosmos 4.0.3-java

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1491) hide show
  1. checksums.yaml +7 -0
  2. data/.coveralls.yml +1 -0
  3. data/.gitattributes +3 -0
  4. data/.gitignore +48 -0
  5. data/.rubocop.yml +23 -0
  6. data/.travis.yml +10 -0
  7. data/.yardopts +3 -0
  8. data/CONTRIBUTING.txt +50 -0
  9. data/Gemfile +10 -0
  10. data/Guardfile +27 -0
  11. data/LICENSE.txt +879 -0
  12. data/Manifest.txt +1549 -0
  13. data/README.md +111 -0
  14. data/Rakefile +264 -0
  15. data/autohotkey/config/data/attitude.bin +0 -0
  16. data/autohotkey/config/data/diamond.STL +58 -0
  17. data/autohotkey/config/data/groundoff.gif +0 -0
  18. data/autohotkey/config/data/groundon.gif +0 -0
  19. data/autohotkey/config/data/position.bin +0 -0
  20. data/autohotkey/config/data/satellite.gif +0 -0
  21. data/autohotkey/config/data/tada.wav +0 -0
  22. data/autohotkey/config/system/system.txt +29 -0
  23. data/autohotkey/config/targets/INST/cmd_tlm/inst_cmds.txt +126 -0
  24. data/autohotkey/config/targets/INST/cmd_tlm/inst_tlm.txt +270 -0
  25. data/autohotkey/config/targets/INST/cmd_tlm_server.txt +5 -0
  26. data/autohotkey/config/targets/INST/doc/README.txt +1 -0
  27. data/autohotkey/config/targets/INST/lib/example_limits_response.rb +30 -0
  28. data/autohotkey/config/targets/INST/lib/sim_inst.rb +305 -0
  29. data/autohotkey/config/targets/INST/screens/_footer.txt +4 -0
  30. data/autohotkey/config/targets/INST/screens/adcs.txt +46 -0
  31. data/autohotkey/config/targets/INST/screens/array.txt +7 -0
  32. data/autohotkey/config/targets/INST/screens/block.txt +8 -0
  33. data/autohotkey/config/targets/INST/screens/commanding.txt +30 -0
  34. data/autohotkey/config/targets/INST/screens/extra.txt +19 -0
  35. data/autohotkey/config/targets/INST/screens/graphs.txt +14 -0
  36. data/autohotkey/config/targets/INST/screens/ground.txt +25 -0
  37. data/autohotkey/config/targets/INST/screens/health_status.txt +33 -0
  38. data/autohotkey/config/targets/INST/screens/hs.txt +46 -0
  39. data/autohotkey/config/targets/INST/screens/image.txt +21 -0
  40. data/autohotkey/config/targets/INST/screens/latest.txt +23 -0
  41. data/autohotkey/config/targets/INST/screens/mech.txt +25 -0
  42. data/autohotkey/config/targets/INST/screens/other.txt +25 -0
  43. data/autohotkey/config/targets/INST/screens/params.txt +25 -0
  44. data/autohotkey/config/targets/INST/screens/tabs.txt +68 -0
  45. data/autohotkey/config/targets/INST/sequences/run_sequence.txt +1 -0
  46. data/autohotkey/config/targets/INST/target.txt +27 -0
  47. data/autohotkey/config/targets/META/cmd_tlm/meta_cmd.txt +10 -0
  48. data/autohotkey/config/targets/META/cmd_tlm/meta_tlm.txt +9 -0
  49. data/autohotkey/config/targets/META/screens/data.txt +12 -0
  50. data/autohotkey/config/targets/SYSTEM/cmd_tlm/limits_groups.txt +7 -0
  51. data/autohotkey/config/targets/SYSTEM/cmd_tlm/meta_cmd_tlm.txt +16 -0
  52. data/autohotkey/config/targets/SYSTEM/cmd_tlm/system_cmds.txt +41 -0
  53. data/autohotkey/config/targets/SYSTEM/cmd_tlm/system_tlm.txt +7 -0
  54. data/autohotkey/config/targets/SYSTEM/screens/error.txt +11 -0
  55. data/autohotkey/config/targets/SYSTEM/screens/limits_change.txt +14 -0
  56. data/autohotkey/config/targets/SYSTEM/screens/meta.txt +14 -0
  57. data/autohotkey/config/targets/SYSTEM/target.txt +12 -0
  58. data/autohotkey/config/tools/cmd_sender/cmd_sender.txt +1 -0
  59. data/autohotkey/config/tools/cmd_tlm_server/cmd_tlm_server.txt +22 -0
  60. data/autohotkey/config/tools/data_viewer/data_viewer.txt +11 -0
  61. data/autohotkey/config/tools/handbook_creator/default_toc.xsl +59 -0
  62. data/autohotkey/config/tools/handbook_creator/handbook_creator.txt +49 -0
  63. data/autohotkey/config/tools/handbook_creator/templates/command_packets.html.erb +86 -0
  64. data/autohotkey/config/tools/handbook_creator/templates/command_toc.html.erb +38 -0
  65. data/autohotkey/config/tools/handbook_creator/templates/footer.html.erb +9 -0
  66. data/autohotkey/config/tools/handbook_creator/templates/header.html.erb +25 -0
  67. data/autohotkey/config/tools/handbook_creator/templates/limits_groups.html.erb +13 -0
  68. data/autohotkey/config/tools/handbook_creator/templates/nav.html.erb +27 -0
  69. data/autohotkey/config/tools/handbook_creator/templates/overview.html.erb +1 -0
  70. data/autohotkey/config/tools/handbook_creator/templates/pdf_cover.html.erb +23 -0
  71. data/autohotkey/config/tools/handbook_creator/templates/pdf_footer.html.erb +33 -0
  72. data/autohotkey/config/tools/handbook_creator/templates/pdf_header.html.erb +41 -0
  73. data/autohotkey/config/tools/handbook_creator/templates/telemetry_packets.html.erb +80 -0
  74. data/autohotkey/config/tools/handbook_creator/templates/telemetry_toc.html.erb +38 -0
  75. data/autohotkey/config/tools/handbook_creator/templates/title.html.erb +1 -0
  76. data/autohotkey/config/tools/launcher/launcher.txt +38 -0
  77. data/autohotkey/config/tools/limits_monitor/README.txt +1 -0
  78. data/autohotkey/config/tools/opengl_builder/error.txt +1 -0
  79. data/autohotkey/config/tools/script_runner/script_runner.txt +3 -0
  80. data/autohotkey/config/tools/table_manager/ConfigTables_def.txt +8 -0
  81. data/autohotkey/config/tools/table_manager/OldOneDimensionalTable_def.txt +19 -0
  82. data/autohotkey/config/tools/table_manager/OldTwoDimensionalTable_def.txt +248 -0
  83. data/autohotkey/config/tools/table_manager/OneDimensionalTable_def.txt +31 -0
  84. data/autohotkey/config/tools/table_manager/TwoDimensionalTable_def.txt +28 -0
  85. data/autohotkey/config/tools/test_runner/test_runner.txt +8 -0
  86. data/autohotkey/config/tools/test_runner/test_runner2.txt +11 -0
  87. data/autohotkey/config/tools/test_runner/test_runner3.txt +7 -0
  88. data/autohotkey/config/tools/test_runner/test_runner4.txt +1 -0
  89. data/autohotkey/config/tools/tlm_extractor/tlm_extractor.txt +14 -0
  90. data/autohotkey/config/tools/tlm_extractor/tlm_extractor2.txt +9 -0
  91. data/autohotkey/config/tools/tlm_grapher/README.txt +1 -0
  92. data/autohotkey/config/tools/tlm_grapher/bad.txt +50 -0
  93. data/autohotkey/config/tools/tlm_grapher/temp1-4.txt +51 -0
  94. data/autohotkey/config/tools/tlm_grapher/test2.txt +111 -0
  95. data/autohotkey/config/tools/tlm_viewer/tlm_viewer.txt +24 -0
  96. data/autohotkey/config/tools/tlm_viewer/tlm_viewer2.txt +4 -0
  97. data/autohotkey/config/tools/tlm_viewer/tlm_viewer3.txt +3 -0
  98. data/autohotkey/lib/example_background_task.rb +42 -0
  99. data/autohotkey/lib/user_version.rb +3 -0
  100. data/autohotkey/procedures/clear_util.rb +7 -0
  101. data/autohotkey/procedures/collect.rb +18 -0
  102. data/autohotkey/procedures/collect_util.rb +14 -0
  103. data/autohotkey/procedures/example_test.rb +71 -0
  104. data/autohotkey/procedures/example_test2.rb +74 -0
  105. data/autohotkey/procedures/script_test.rb +21 -0
  106. data/autohotkey/procedures/syntax_error.rb +18 -0
  107. data/autohotkey/tools/CmdExtractorAHK +16 -0
  108. data/autohotkey/tools/CmdSender +14 -0
  109. data/autohotkey/tools/CmdSenderAHK +18 -0
  110. data/autohotkey/tools/CmdSequence +14 -0
  111. data/autohotkey/tools/CmdSequenceAHK +23 -0
  112. data/autohotkey/tools/CmdSequenceAHK2 +16 -0
  113. data/autohotkey/tools/CmdTlmServer +14 -0
  114. data/autohotkey/tools/CmdTlmServerAHK +28 -0
  115. data/autohotkey/tools/CmdTlmServerAHK2 +17 -0
  116. data/autohotkey/tools/ConfigEditor +16 -0
  117. data/autohotkey/tools/DataViewer +14 -0
  118. data/autohotkey/tools/DataViewerAHK +17 -0
  119. data/autohotkey/tools/HandbookCreatorAHK +20 -0
  120. data/autohotkey/tools/LauncherAHK +17 -0
  121. data/autohotkey/tools/LimitsMonitorAHK +20 -0
  122. data/autohotkey/tools/OpenGLBuilderAHK +24 -0
  123. data/autohotkey/tools/PacketViewer +14 -0
  124. data/autohotkey/tools/PacketViewerAHK +18 -0
  125. data/autohotkey/tools/PacketViewerAHK2 +17 -0
  126. data/autohotkey/tools/Replay +14 -0
  127. data/autohotkey/tools/ReplayAHK +17 -0
  128. data/autohotkey/tools/ScriptRunner +14 -0
  129. data/autohotkey/tools/ScriptRunnerAHK +20 -0
  130. data/autohotkey/tools/ScriptRunnerAHK2 +17 -0
  131. data/autohotkey/tools/TableManager +14 -0
  132. data/autohotkey/tools/TableManagerAHK +25 -0
  133. data/autohotkey/tools/TableManagerAHK2 +18 -0
  134. data/autohotkey/tools/TableManagerAHK3 +18 -0
  135. data/autohotkey/tools/TableManagerAHK4 +24 -0
  136. data/autohotkey/tools/TestRunner +15 -0
  137. data/autohotkey/tools/TestRunnerAHK +17 -0
  138. data/autohotkey/tools/TestRunnerAHK2 +17 -0
  139. data/autohotkey/tools/TestRunnerAHK3 +17 -0
  140. data/autohotkey/tools/TestRunnerAHK4 +17 -0
  141. data/autohotkey/tools/TestRunnerAHK5 +17 -0
  142. data/autohotkey/tools/TestRunnerAHK6 +17 -0
  143. data/autohotkey/tools/TlmExtractor +15 -0
  144. data/autohotkey/tools/TlmExtractorAHK +19 -0
  145. data/autohotkey/tools/TlmExtractorAHK2 +16 -0
  146. data/autohotkey/tools/TlmExtractorAHK3 +16 -0
  147. data/autohotkey/tools/TlmGrapher +14 -0
  148. data/autohotkey/tools/TlmGrapherAHK +19 -0
  149. data/autohotkey/tools/TlmGrapherAHK2 +23 -0
  150. data/autohotkey/tools/TlmGrapherAHK3 +17 -0
  151. data/autohotkey/tools/TlmGrapherAHK4 +17 -0
  152. data/autohotkey/tools/TlmViewer +14 -0
  153. data/autohotkey/tools/TlmViewerAHK +28 -0
  154. data/autohotkey/tools/TlmViewerAHK2 +22 -0
  155. data/autohotkey/tools/TlmViewerAHK3 +23 -0
  156. data/autohotkey/tools/TlmViewerAHK4 +22 -0
  157. data/autohotkey/tools/TlmViewerAHK5 +18 -0
  158. data/autohotkey/tools/autohotkey.rb +38 -0
  159. data/autohotkey/tools/cmd_extractor.ahk +50 -0
  160. data/autohotkey/tools/cmd_sender.ahk +180 -0
  161. data/autohotkey/tools/cmd_sequence.ahk +215 -0
  162. data/autohotkey/tools/cmd_sequence2.ahk +23 -0
  163. data/autohotkey/tools/cmd_tlm_server.ahk +90 -0
  164. data/autohotkey/tools/cmd_tlm_server2.ahk +45 -0
  165. data/autohotkey/tools/data_viewer.ahk +140 -0
  166. data/autohotkey/tools/handbook_creator.ahk +32 -0
  167. data/autohotkey/tools/launcher.ahk +41 -0
  168. data/autohotkey/tools/limits_monitor.ahk +121 -0
  169. data/autohotkey/tools/open_gl_builder.ahk +133 -0
  170. data/autohotkey/tools/packet_viewer.ahk +217 -0
  171. data/autohotkey/tools/packet_viewer2.ahk +9 -0
  172. data/autohotkey/tools/replay.ahk +103 -0
  173. data/autohotkey/tools/script_runner.ahk +588 -0
  174. data/autohotkey/tools/script_runner2.ahk +50 -0
  175. data/autohotkey/tools/table_manager.ahk +291 -0
  176. data/autohotkey/tools/test_runner.ahk +262 -0
  177. data/autohotkey/tools/test_runner2.ahk +49 -0
  178. data/autohotkey/tools/test_runner3.ahk +11 -0
  179. data/autohotkey/tools/test_runner5.ahk +8 -0
  180. data/autohotkey/tools/test_runner6.ahk +5 -0
  181. data/autohotkey/tools/tlm_extractor.ahk +357 -0
  182. data/autohotkey/tools/tlm_grapher.ahk +658 -0
  183. data/autohotkey/tools/tlm_grapher2.ahk +115 -0
  184. data/autohotkey/tools/tlm_grapher3.ahk +23 -0
  185. data/autohotkey/tools/tlm_viewer.ahk +140 -0
  186. data/autohotkey/tools/tlm_viewer2.ahk +49 -0
  187. data/autohotkey/tools/tlm_viewer4.ahk +4 -0
  188. data/autohotkey/tools/tlm_viewer5.ahk +19 -0
  189. data/autohotkey/tools/tool_launch.rb +38 -0
  190. data/bin/cosmos +266 -0
  191. data/bin/cstol_converter +1166 -0
  192. data/bin/exchndl20-x64.dll +0 -0
  193. data/bin/exchndl20.dll +0 -0
  194. data/bin/exchndl21-x64.dll +0 -0
  195. data/bin/exchndl21.dll +0 -0
  196. data/bin/exchndl22-x64.dll +0 -0
  197. data/bin/exchndl22.dll +0 -0
  198. data/bin/mgwhelp-x64.dll +0 -0
  199. data/bin/mgwhelp.dll +0 -0
  200. data/bin/rubysloc +85 -0
  201. data/bin/xtce_converter +83 -0
  202. data/cosmos.gemspec +109 -0
  203. data/data/COSMOS_64x64.bmp +0 -0
  204. data/data/COSMOS_64x64.ico +0 -0
  205. data/data/COSMOS_64x64.png +0 -0
  206. data/data/COSMOS_Architecture.png +0 -0
  207. data/data/CheckBoxCheck.gif +0 -0
  208. data/data/CheckBoxEmpty.gif +0 -0
  209. data/data/Earthmap1024x512.gif +0 -0
  210. data/data/about.txt +4 -0
  211. data/data/add_database.png +0 -0
  212. data/data/add_plot.png +0 -0
  213. data/data/add_tab.png +0 -0
  214. data/data/blank.png +0 -0
  215. data/data/bug.png +0 -0
  216. data/data/checkmark.png +0 -0
  217. data/data/close.png +0 -0
  218. data/data/cmd_extractor.png +0 -0
  219. data/data/cmd_sender.png +0 -0
  220. data/data/cmd_sequence.png +0 -0
  221. data/data/config/_array_params.yaml +23 -0
  222. data/data/config/_id_items.yaml +24 -0
  223. data/data/config/_id_params.yaml +58 -0
  224. data/data/config/_interfaces.yaml +206 -0
  225. data/data/config/_items.yaml +20 -0
  226. data/data/config/_params.yaml +58 -0
  227. data/data/config/cmd_tlm_server.yaml +124 -0
  228. data/data/config/command.yaml +40 -0
  229. data/data/config/command_modifiers.yaml +145 -0
  230. data/data/config/command_telemetry.yaml +3 -0
  231. data/data/config/data_viewer.yaml +43 -0
  232. data/data/config/handbook_creator.yaml +23 -0
  233. data/data/config/housekeeping_params.yaml +71 -0
  234. data/data/config/interface_modifiers.yaml +44 -0
  235. data/data/config/item_modifiers.yaml +211 -0
  236. data/data/config/launcher.yaml +117 -0
  237. data/data/config/limits_monitor.yaml +53 -0
  238. data/data/config/linegraph_params.yaml +30 -0
  239. data/data/config/linegraph_plot.yaml +106 -0
  240. data/data/config/page_modifiers.yaml +128 -0
  241. data/data/config/param_item_modifiers.yaml +46 -0
  242. data/data/config/parameter_modifiers.yaml +180 -0
  243. data/data/config/protocols.yaml +273 -0
  244. data/data/config/screen.yaml +151 -0
  245. data/data/config/script_runner.yaml +15 -0
  246. data/data/config/system.yaml +247 -0
  247. data/data/config/table_manager.yaml +76 -0
  248. data/data/config/table_parameter_modifiers.yaml +9 -0
  249. data/data/config/target.yaml +80 -0
  250. data/data/config/telemetry.yaml +80 -0
  251. data/data/config/telemetry_modifiers.yaml +142 -0
  252. data/data/config/test_runner.yaml +118 -0
  253. data/data/config/tlm_extractor.yaml +109 -0
  254. data/data/config/tlm_grapher.yaml +78 -0
  255. data/data/config/tlm_viewer.yaml +112 -0
  256. data/data/config/unknown.yaml +3 -0
  257. data/data/config/widgets.yaml +1339 -0
  258. data/data/config/xy_params.yaml +50 -0
  259. data/data/config/xy_plot.yaml +12 -0
  260. data/data/config_editor.png +0 -0
  261. data/data/copy.png +0 -0
  262. data/data/cosmos.xcf +0 -0
  263. data/data/cosmos_word.gif +0 -0
  264. data/data/crc.txt +351 -0
  265. data/data/critical.wav +0 -0
  266. data/data/cts.png +0 -0
  267. data/data/cut.png +0 -0
  268. data/data/data_viewer.png +0 -0
  269. data/data/delete.png +0 -0
  270. data/data/delete_database.png +0 -0
  271. data/data/delete_plot.png +0 -0
  272. data/data/delete_tab.png +0 -0
  273. data/data/diamond.STL +58 -0
  274. data/data/disconnected.png +0 -0
  275. data/data/edit.png +0 -0
  276. data/data/edit_database.png +0 -0
  277. data/data/edit_plot.png +0 -0
  278. data/data/edit_tab.png +0 -0
  279. data/data/end-26.png +0 -0
  280. data/data/fast_forward-26.png +0 -0
  281. data/data/file.png +0 -0
  282. data/data/handbook_creator.png +0 -0
  283. data/data/help.png +0 -0
  284. data/data/html-32.png +0 -0
  285. data/data/information.wav +0 -0
  286. data/data/input.wav +0 -0
  287. data/data/launcher.png +0 -0
  288. data/data/legal.gif +0 -0
  289. data/data/legal.txt +8 -0
  290. data/data/limits_monitor.png +0 -0
  291. data/data/message.wav +0 -0
  292. data/data/moonmap1k.gif +0 -0
  293. data/data/multi.png +0 -0
  294. data/data/open.png +0 -0
  295. data/data/open_in_browser-32.png +0 -0
  296. data/data/opengl_builder.png +0 -0
  297. data/data/packet_viewer.png +0 -0
  298. data/data/pdf-32.png +0 -0
  299. data/data/play-26.png +0 -0
  300. data/data/question.wav +0 -0
  301. data/data/redo.png +0 -0
  302. data/data/replay.png +0 -0
  303. data/data/reverse-play-26.png +0 -0
  304. data/data/rewind-26.png +0 -0
  305. data/data/running.png +0 -0
  306. data/data/save.png +0 -0
  307. data/data/save_as.png +0 -0
  308. data/data/screenshot.png +0 -0
  309. data/data/script_runner.png +0 -0
  310. data/data/search-14.png +0 -0
  311. data/data/search.png +0 -0
  312. data/data/send_file.png +0 -0
  313. data/data/skip_to_start-26.png +0 -0
  314. data/data/spinner.gif +0 -0
  315. data/data/splash.gif +0 -0
  316. data/data/stop-26.png +0 -0
  317. data/data/table_manager.png +0 -0
  318. data/data/test_runner.png +0 -0
  319. data/data/tlm_extractor.png +0 -0
  320. data/data/tlm_grapher.png +0 -0
  321. data/data/tlm_viewer.png +0 -0
  322. data/data/undo.png +0 -0
  323. data/data/warning.wav +0 -0
  324. data/demo/Gemfile +10 -0
  325. data/demo/Launcher +16 -0
  326. data/demo/Launcher.bat +9 -0
  327. data/demo/Rakefile +77 -0
  328. data/demo/config/data/attitude.bin +0 -0
  329. data/demo/config/data/crc.txt +258 -0
  330. data/demo/config/data/diamond.STL +58 -0
  331. data/demo/config/data/groundoff.gif +0 -0
  332. data/demo/config/data/groundon.gif +0 -0
  333. data/demo/config/data/hselectoff.gif +0 -0
  334. data/demo/config/data/hselecton.gif +0 -0
  335. data/demo/config/data/hswitchoff.gif +0 -0
  336. data/demo/config/data/hswitchon.gif +0 -0
  337. data/demo/config/data/meta_init.txt +1 -0
  338. data/demo/config/data/position.bin +0 -0
  339. data/demo/config/data/poweroff.gif +0 -0
  340. data/demo/config/data/poweron.gif +0 -0
  341. data/demo/config/data/satellite.gif +0 -0
  342. data/demo/config/data/tada.wav +0 -0
  343. data/demo/config/data/vswitchoff.gif +0 -0
  344. data/demo/config/data/vswitchon.gif +0 -0
  345. data/demo/config/system/system.txt +47 -0
  346. data/demo/config/system/system2.txt +43 -0
  347. data/demo/config/targets/EXAMPLE/cmd_tlm/example_cmds.txt +2 -0
  348. data/demo/config/targets/EXAMPLE/cmd_tlm/example_tlm.txt +5 -0
  349. data/demo/config/targets/EXAMPLE/cmd_tlm_server.txt +6 -0
  350. data/demo/config/targets/EXAMPLE/lib/example_interface.rb +18 -0
  351. data/demo/config/targets/EXAMPLE/target.txt +9 -0
  352. data/demo/config/targets/INST/cmd_tlm/_ccsds_cmd.txt +9 -0
  353. data/demo/config/targets/INST/cmd_tlm/_ccsds_tlm.txt +19 -0
  354. data/demo/config/targets/INST/cmd_tlm/inst_cmds.txt +57 -0
  355. data/demo/config/targets/INST/cmd_tlm/inst_tlm.txt +164 -0
  356. data/demo/config/targets/INST/cmd_tlm_server.txt +5 -0
  357. data/demo/config/targets/INST/doc/README.txt +1 -0
  358. data/demo/config/targets/INST/lib/example_limits_response.rb +30 -0
  359. data/demo/config/targets/INST/lib/inst_dump_component.rb +34 -0
  360. data/demo/config/targets/INST/lib/sim_inst.rb +321 -0
  361. data/demo/config/targets/INST/procedures/checks.rb +11 -0
  362. data/demo/config/targets/INST/procedures/collect.rb +18 -0
  363. data/demo/config/targets/INST/procedures/disconnect.rb +29 -0
  364. data/demo/config/targets/INST/procedures/utilities/clear.rb +7 -0
  365. data/demo/config/targets/INST/procedures/utilities/collect.rb +14 -0
  366. data/demo/config/targets/INST/screens/_footer.txt +4 -0
  367. data/demo/config/targets/INST/screens/adcs.txt +70 -0
  368. data/demo/config/targets/INST/screens/array.txt +15 -0
  369. data/demo/config/targets/INST/screens/block.txt +8 -0
  370. data/demo/config/targets/INST/screens/commanding.txt +37 -0
  371. data/demo/config/targets/INST/screens/graphs.txt +14 -0
  372. data/demo/config/targets/INST/screens/ground.txt +25 -0
  373. data/demo/config/targets/INST/screens/hs.txt +42 -0
  374. data/demo/config/targets/INST/screens/latest.txt +23 -0
  375. data/demo/config/targets/INST/screens/limits.txt +43 -0
  376. data/demo/config/targets/INST/screens/other.txt +24 -0
  377. data/demo/config/targets/INST/screens/spacing_box.txt +44 -0
  378. data/demo/config/targets/INST/screens/spacing_grid.txt +78 -0
  379. data/demo/config/targets/INST/screens/tabs.txt +68 -0
  380. data/demo/config/targets/INST/sequences/sequence.tsv +3 -0
  381. data/demo/config/targets/INST/tables/EventAction.csv +9 -0
  382. data/demo/config/targets/INST/tables/EventAction.dat +0 -0
  383. data/demo/config/targets/INST/tables/McConfigTable.csv +20 -0
  384. data/demo/config/targets/INST/tables/McConfigTable.dat +0 -0
  385. data/demo/config/targets/INST/target.txt +37 -0
  386. data/demo/config/targets/INST/tools/data_viewer/data_viewer.txt +2 -0
  387. data/demo/config/targets/INST/tools/data_viewer/data_viewer2.txt +2 -0
  388. data/demo/config/targets/INST/tools/table_manager/EventAction_def.txt +6 -0
  389. data/demo/config/targets/INST/tools/table_manager/McConfigTable_def.txt +38 -0
  390. data/demo/config/targets/SYSTEM/cmd_tlm/limits_groups.txt +6 -0
  391. data/demo/config/targets/SYSTEM/cmd_tlm/meta_tlm.txt +10 -0
  392. data/demo/config/targets/SYSTEM/cmd_tlm/override.txt +29 -0
  393. data/demo/config/targets/SYSTEM/cmd_tlm/system_cmds.txt +41 -0
  394. data/demo/config/targets/SYSTEM/cmd_tlm/system_tlm.txt +7 -0
  395. data/demo/config/targets/SYSTEM/cmd_tlm_server.txt +6 -0
  396. data/demo/config/targets/SYSTEM/lib/limits_groups.rb +55 -0
  397. data/demo/config/targets/SYSTEM/screens/status.txt +12 -0
  398. data/demo/config/targets/SYSTEM/target.txt +12 -0
  399. data/demo/config/targets/TEMPLATED/cmd_tlm/templated_cmds.txt +13 -0
  400. data/demo/config/targets/TEMPLATED/cmd_tlm/templated_tlm.txt +3 -0
  401. data/demo/config/targets/TEMPLATED/cmd_tlm_server.txt +6 -0
  402. data/demo/config/targets/TEMPLATED/lib/templated_interface.rb +59 -0
  403. data/demo/config/targets/TEMPLATED/target.txt +8 -0
  404. data/demo/config/tools/cmd_tlm_server/cmd_tlm_server.txt +49 -0
  405. data/demo/config/tools/cmd_tlm_server/cmd_tlm_server2.txt +42 -0
  406. data/demo/config/tools/data_viewer/data_viewer.txt +20 -0
  407. data/demo/config/tools/example_application.css +58 -0
  408. data/demo/config/tools/handbook_creator/default_toc.xsl +59 -0
  409. data/demo/config/tools/handbook_creator/handbook_creator.txt +66 -0
  410. data/demo/config/tools/handbook_creator/templates/command_packets.html.erb +88 -0
  411. data/demo/config/tools/handbook_creator/templates/command_toc.html.erb +38 -0
  412. data/demo/config/tools/handbook_creator/templates/footer.html.erb +9 -0
  413. data/demo/config/tools/handbook_creator/templates/header.html.erb +25 -0
  414. data/demo/config/tools/handbook_creator/templates/limits_groups.html.erb +13 -0
  415. data/demo/config/tools/handbook_creator/templates/nav.html.erb +27 -0
  416. data/demo/config/tools/handbook_creator/templates/overview.html.erb +1 -0
  417. data/demo/config/tools/handbook_creator/templates/pdf_cover.html.erb +23 -0
  418. data/demo/config/tools/handbook_creator/templates/pdf_footer.html.erb +33 -0
  419. data/demo/config/tools/handbook_creator/templates/pdf_header.html.erb +41 -0
  420. data/demo/config/tools/handbook_creator/templates/telemetry_packets.html.erb +82 -0
  421. data/demo/config/tools/handbook_creator/templates/telemetry_toc.html.erb +38 -0
  422. data/demo/config/tools/handbook_creator/templates/title.html.erb +1 -0
  423. data/demo/config/tools/launcher/launcher.css +7 -0
  424. data/demo/config/tools/launcher/launcher.txt +48 -0
  425. data/demo/config/tools/launcher/launcher2.css +10 -0
  426. data/demo/config/tools/launcher/launcher2.txt +48 -0
  427. data/demo/config/tools/launcher/launcher_mini.txt +45 -0
  428. data/demo/config/tools/limits_monitor/README.txt +1 -0
  429. data/demo/config/tools/opengl_builder/README.txt +1 -0
  430. data/demo/config/tools/script_runner/script_runner.txt +3 -0
  431. data/demo/config/tools/table_manager/ConfigTables_def.txt +8 -0
  432. data/demo/config/tools/table_manager/ExampleTableDefinition.txt +24 -0
  433. data/demo/config/tools/table_manager/MCConfigurationTable_fsw1_def.txt +37 -0
  434. data/demo/config/tools/table_manager/MCConfigurationTable_fsw2_def.txt +34 -0
  435. data/demo/config/tools/table_manager/PPSSelectionTable_def.txt +9 -0
  436. data/demo/config/tools/table_manager/TLMMonitoringTable_def.txt +31 -0
  437. data/demo/config/tools/test_runner/test_runner.css +45 -0
  438. data/demo/config/tools/test_runner/test_runner.txt +17 -0
  439. data/demo/config/tools/tlm_extractor/_adcs_time.txt +2 -0
  440. data/demo/config/tools/tlm_extractor/tlm_extractor.txt +13 -0
  441. data/demo/config/tools/tlm_extractor/tlm_extractor2.txt +2 -0
  442. data/demo/config/tools/tlm_extractor/tlm_extractor3.txt +2 -0
  443. data/demo/config/tools/tlm_extractor/tlm_extractor4.txt +2 -0
  444. data/demo/config/tools/tlm_grapher/README.txt +1 -0
  445. data/demo/config/tools/tlm_viewer/tlm_viewer.txt +41 -0
  446. data/demo/lib/example_background_task.rb +55 -0
  447. data/demo/lib/example_target.rb +103 -0
  448. data/demo/lib/scpi_target.rb +68 -0
  449. data/demo/lib/user_version.rb +3 -0
  450. data/demo/procedures/cosmos_api_test.rb +310 -0
  451. data/demo/procedures/example_test.rb +192 -0
  452. data/demo/procedures/plot_test.rb +8 -0
  453. data/demo/procedures/run_example_test.rb +3 -0
  454. data/demo/procedures/test.rb +51 -0
  455. data/demo/tools/CmdExtractor +16 -0
  456. data/demo/tools/CmdExtractor.bat +9 -0
  457. data/demo/tools/CmdSender +16 -0
  458. data/demo/tools/CmdSender.bat +9 -0
  459. data/demo/tools/CmdSequence +16 -0
  460. data/demo/tools/CmdSequence.bat +9 -0
  461. data/demo/tools/CmdTlmServer +16 -0
  462. data/demo/tools/CmdTlmServer.bat +9 -0
  463. data/demo/tools/ConfigEditor +16 -0
  464. data/demo/tools/ConfigEditor.bat +9 -0
  465. data/demo/tools/DataViewer +16 -0
  466. data/demo/tools/DataViewer.bat +9 -0
  467. data/demo/tools/ExampleTarget +16 -0
  468. data/demo/tools/ExampleTarget.bat +9 -0
  469. data/demo/tools/HandbookCreator +16 -0
  470. data/demo/tools/HandbookCreator.bat +9 -0
  471. data/demo/tools/Launcher +16 -0
  472. data/demo/tools/Launcher.bat +9 -0
  473. data/demo/tools/LimitsMonitor +16 -0
  474. data/demo/tools/LimitsMonitor.bat +9 -0
  475. data/demo/tools/OpenGLBuilder +16 -0
  476. data/demo/tools/OpenGLBuilder.bat +9 -0
  477. data/demo/tools/PacketViewer +16 -0
  478. data/demo/tools/PacketViewer.bat +9 -0
  479. data/demo/tools/Replay +16 -0
  480. data/demo/tools/Replay.bat +9 -0
  481. data/demo/tools/ScpiTarget +16 -0
  482. data/demo/tools/ScpiTarget.bat +9 -0
  483. data/demo/tools/ScriptRunner +16 -0
  484. data/demo/tools/ScriptRunner.bat +9 -0
  485. data/demo/tools/TableManager +16 -0
  486. data/demo/tools/TableManager.bat +9 -0
  487. data/demo/tools/TestRunner +16 -0
  488. data/demo/tools/TestRunner.bat +9 -0
  489. data/demo/tools/TlmExtractor +16 -0
  490. data/demo/tools/TlmExtractor.bat +9 -0
  491. data/demo/tools/TlmGrapher +16 -0
  492. data/demo/tools/TlmGrapher.bat +9 -0
  493. data/demo/tools/TlmViewer +16 -0
  494. data/demo/tools/TlmViewer.bat +9 -0
  495. data/demo/tools/ToolLaunch.bat +72 -0
  496. data/demo/tools/mac/CmdExtractor.app/Contents/Info.plist +38 -0
  497. data/demo/tools/mac/CmdExtractor.app/Contents/MacOS/CmdExtractor.rb +16 -0
  498. data/demo/tools/mac/CmdExtractor.app/Contents/MacOS/main.sh +10 -0
  499. data/demo/tools/mac/CmdExtractor.app/Contents/MacOS/tool_launch.rb +38 -0
  500. data/demo/tools/mac/CmdExtractor.app/Contents/Resources/appIcon.icns +0 -0
  501. data/demo/tools/mac/CmdSender.app/Contents/Info.plist +38 -0
  502. data/demo/tools/mac/CmdSender.app/Contents/MacOS/CmdSender.rb +16 -0
  503. data/demo/tools/mac/CmdSender.app/Contents/MacOS/main.sh +10 -0
  504. data/demo/tools/mac/CmdSender.app/Contents/MacOS/tool_launch.rb +38 -0
  505. data/demo/tools/mac/CmdSender.app/Contents/Resources/appIcon.icns +0 -0
  506. data/demo/tools/mac/CmdSequence.app/Contents/Info.plist +38 -0
  507. data/demo/tools/mac/CmdSequence.app/Contents/MacOS/CmdSequence.rb +16 -0
  508. data/demo/tools/mac/CmdSequence.app/Contents/MacOS/main.sh +10 -0
  509. data/demo/tools/mac/CmdSequence.app/Contents/MacOS/tool_launch.rb +38 -0
  510. data/demo/tools/mac/CmdSequence.app/Contents/Resources/appIcon.icns +0 -0
  511. data/demo/tools/mac/CmdTlmServer.app/Contents/Info.plist +38 -0
  512. data/demo/tools/mac/CmdTlmServer.app/Contents/MacOS/CmdTlmServer.rb +16 -0
  513. data/demo/tools/mac/CmdTlmServer.app/Contents/MacOS/main.sh +10 -0
  514. data/demo/tools/mac/CmdTlmServer.app/Contents/MacOS/tool_launch.rb +38 -0
  515. data/demo/tools/mac/CmdTlmServer.app/Contents/Resources/appIcon.icns +0 -0
  516. data/demo/tools/mac/ConfigEditor.app/Contents/Info.plist +38 -0
  517. data/demo/tools/mac/ConfigEditor.app/Contents/MacOS/ConfigEditor.rb +16 -0
  518. data/demo/tools/mac/ConfigEditor.app/Contents/MacOS/main.sh +10 -0
  519. data/demo/tools/mac/ConfigEditor.app/Contents/MacOS/tool_launch.rb +38 -0
  520. data/demo/tools/mac/ConfigEditor.app/Contents/Resources/appIcon.icns +0 -0
  521. data/demo/tools/mac/DataViewer.app/Contents/Info.plist +38 -0
  522. data/demo/tools/mac/DataViewer.app/Contents/MacOS/DataViewer.rb +16 -0
  523. data/demo/tools/mac/DataViewer.app/Contents/MacOS/main.sh +10 -0
  524. data/demo/tools/mac/DataViewer.app/Contents/MacOS/tool_launch.rb +38 -0
  525. data/demo/tools/mac/DataViewer.app/Contents/Resources/appIcon.icns +0 -0
  526. data/demo/tools/mac/HandbookCreator.app/Contents/Info.plist +38 -0
  527. data/demo/tools/mac/HandbookCreator.app/Contents/MacOS/HandbookCreator.rb +16 -0
  528. data/demo/tools/mac/HandbookCreator.app/Contents/MacOS/main.sh +10 -0
  529. data/demo/tools/mac/HandbookCreator.app/Contents/MacOS/tool_launch.rb +38 -0
  530. data/demo/tools/mac/HandbookCreator.app/Contents/Resources/appIcon.icns +0 -0
  531. data/demo/tools/mac/Launcher.app/Contents/Info.plist +38 -0
  532. data/demo/tools/mac/Launcher.app/Contents/MacOS/Launcher.rb +16 -0
  533. data/demo/tools/mac/Launcher.app/Contents/MacOS/main.sh +10 -0
  534. data/demo/tools/mac/Launcher.app/Contents/MacOS/tool_launch.rb +38 -0
  535. data/demo/tools/mac/Launcher.app/Contents/Resources/appIcon.icns +0 -0
  536. data/demo/tools/mac/LimitsMonitor.app/Contents/Info.plist +38 -0
  537. data/demo/tools/mac/LimitsMonitor.app/Contents/MacOS/LimitsMonitor.rb +16 -0
  538. data/demo/tools/mac/LimitsMonitor.app/Contents/MacOS/main.sh +10 -0
  539. data/demo/tools/mac/LimitsMonitor.app/Contents/MacOS/tool_launch.rb +38 -0
  540. data/demo/tools/mac/LimitsMonitor.app/Contents/Resources/appIcon.icns +0 -0
  541. data/demo/tools/mac/OpenGLBuilder.app/Contents/Info.plist +38 -0
  542. data/demo/tools/mac/OpenGLBuilder.app/Contents/MacOS/OpenGLBuilder.rb +16 -0
  543. data/demo/tools/mac/OpenGLBuilder.app/Contents/MacOS/main.sh +10 -0
  544. data/demo/tools/mac/OpenGLBuilder.app/Contents/MacOS/tool_launch.rb +38 -0
  545. data/demo/tools/mac/OpenGLBuilder.app/Contents/Resources/appIcon.icns +0 -0
  546. data/demo/tools/mac/PacketViewer.app/Contents/Info.plist +38 -0
  547. data/demo/tools/mac/PacketViewer.app/Contents/MacOS/PacketViewer.rb +16 -0
  548. data/demo/tools/mac/PacketViewer.app/Contents/MacOS/main.sh +10 -0
  549. data/demo/tools/mac/PacketViewer.app/Contents/MacOS/tool_launch.rb +38 -0
  550. data/demo/tools/mac/PacketViewer.app/Contents/Resources/appIcon.icns +0 -0
  551. data/demo/tools/mac/Replay.app/Contents/Info.plist +38 -0
  552. data/demo/tools/mac/Replay.app/Contents/MacOS/Replay.rb +16 -0
  553. data/demo/tools/mac/Replay.app/Contents/MacOS/main.sh +10 -0
  554. data/demo/tools/mac/Replay.app/Contents/MacOS/tool_launch.rb +38 -0
  555. data/demo/tools/mac/Replay.app/Contents/Resources/appIcon.icns +0 -0
  556. data/demo/tools/mac/ScriptRunner.app/Contents/Info.plist +38 -0
  557. data/demo/tools/mac/ScriptRunner.app/Contents/MacOS/ScriptRunner.rb +16 -0
  558. data/demo/tools/mac/ScriptRunner.app/Contents/MacOS/main.sh +10 -0
  559. data/demo/tools/mac/ScriptRunner.app/Contents/MacOS/tool_launch.rb +38 -0
  560. data/demo/tools/mac/ScriptRunner.app/Contents/Resources/appIcon.icns +0 -0
  561. data/demo/tools/mac/TableManager.app/Contents/Info.plist +38 -0
  562. data/demo/tools/mac/TableManager.app/Contents/MacOS/TableManager.rb +16 -0
  563. data/demo/tools/mac/TableManager.app/Contents/MacOS/main.sh +10 -0
  564. data/demo/tools/mac/TableManager.app/Contents/MacOS/tool_launch.rb +38 -0
  565. data/demo/tools/mac/TableManager.app/Contents/Resources/appIcon.icns +0 -0
  566. data/demo/tools/mac/TestRunner.app/Contents/Info.plist +38 -0
  567. data/demo/tools/mac/TestRunner.app/Contents/MacOS/TestRunner.rb +16 -0
  568. data/demo/tools/mac/TestRunner.app/Contents/MacOS/main.sh +10 -0
  569. data/demo/tools/mac/TestRunner.app/Contents/MacOS/tool_launch.rb +38 -0
  570. data/demo/tools/mac/TestRunner.app/Contents/Resources/appIcon.icns +0 -0
  571. data/demo/tools/mac/TlmExtractor.app/Contents/Info.plist +38 -0
  572. data/demo/tools/mac/TlmExtractor.app/Contents/MacOS/TlmExtractor.rb +16 -0
  573. data/demo/tools/mac/TlmExtractor.app/Contents/MacOS/main.sh +10 -0
  574. data/demo/tools/mac/TlmExtractor.app/Contents/MacOS/tool_launch.rb +38 -0
  575. data/demo/tools/mac/TlmExtractor.app/Contents/Resources/appIcon.icns +0 -0
  576. data/demo/tools/mac/TlmGrapher.app/Contents/Info.plist +38 -0
  577. data/demo/tools/mac/TlmGrapher.app/Contents/MacOS/TlmGrapher.rb +16 -0
  578. data/demo/tools/mac/TlmGrapher.app/Contents/MacOS/main.sh +10 -0
  579. data/demo/tools/mac/TlmGrapher.app/Contents/MacOS/tool_launch.rb +38 -0
  580. data/demo/tools/mac/TlmGrapher.app/Contents/Resources/appIcon.icns +0 -0
  581. data/demo/tools/mac/TlmViewer.app/Contents/Info.plist +38 -0
  582. data/demo/tools/mac/TlmViewer.app/Contents/MacOS/TlmViewer.rb +16 -0
  583. data/demo/tools/mac/TlmViewer.app/Contents/MacOS/main.sh +10 -0
  584. data/demo/tools/mac/TlmViewer.app/Contents/MacOS/tool_launch.rb +38 -0
  585. data/demo/tools/mac/TlmViewer.app/Contents/Resources/appIcon.icns +0 -0
  586. data/demo/tools/tool_launch.rb +38 -0
  587. data/ext/cosmos/ext/array/array.c +111 -0
  588. data/ext/cosmos/ext/array/extconf.rb +13 -0
  589. data/ext/cosmos/ext/buffered_file/buffered_file.c +167 -0
  590. data/ext/cosmos/ext/buffered_file/extconf.rb +13 -0
  591. data/ext/cosmos/ext/config_parser/config_parser.c +237 -0
  592. data/ext/cosmos/ext/config_parser/extconf.rb +13 -0
  593. data/ext/cosmos/ext/cosmos_io/cosmos_io.c +117 -0
  594. data/ext/cosmos/ext/cosmos_io/extconf.rb +13 -0
  595. data/ext/cosmos/ext/crc/crc.c +341 -0
  596. data/ext/cosmos/ext/crc/extconf.rb +13 -0
  597. data/ext/cosmos/ext/line_graph/extconf.rb +13 -0
  598. data/ext/cosmos/ext/line_graph/line_graph.c +501 -0
  599. data/ext/cosmos/ext/low_fragmentation_array/extconf.rb +13 -0
  600. data/ext/cosmos/ext/low_fragmentation_array/low_fragmentation_array.c +265 -0
  601. data/ext/cosmos/ext/packet/extconf.rb +13 -0
  602. data/ext/cosmos/ext/packet/packet.c +350 -0
  603. data/ext/cosmos/ext/platform/extconf.rb +13 -0
  604. data/ext/cosmos/ext/platform/platform.c +101 -0
  605. data/ext/cosmos/ext/polynomial_conversion/extconf.rb +13 -0
  606. data/ext/cosmos/ext/polynomial_conversion/polynomial_conversion.c +73 -0
  607. data/ext/cosmos/ext/string/extconf.rb +13 -0
  608. data/ext/cosmos/ext/string/string.c +49 -0
  609. data/ext/cosmos/ext/structure/structure.c +1433 -0
  610. data/ext/cosmos/ext/tabbed_plots_config/extconf.rb +13 -0
  611. data/ext/cosmos/ext/tabbed_plots_config/tabbed_plots_config.c +51 -0
  612. data/ext/cosmos/ext/telemetry/extconf.rb +13 -0
  613. data/ext/cosmos/ext/telemetry/telemetry.c +307 -0
  614. data/ext/mkrf_conf.rb +40 -0
  615. data/install/Gemfile +10 -0
  616. data/install/Launcher +16 -0
  617. data/install/Launcher.bat +9 -0
  618. data/install/Rakefile +77 -0
  619. data/install/config/data/README.txt +1 -0
  620. data/install/config/data/crc.txt +160 -0
  621. data/install/config/system/system.txt +39 -0
  622. data/install/config/targets/SYSTEM/cmd_tlm/meta_tlm.txt +9 -0
  623. data/install/config/targets/SYSTEM/target.txt +12 -0
  624. data/install/config/tools/cmd_tlm_server/cmd_tlm_server.txt +2 -0
  625. data/install/config/tools/data_viewer/data_viewer.txt +4 -0
  626. data/install/config/tools/handbook_creator/default_toc.xsl +59 -0
  627. data/install/config/tools/handbook_creator/handbook_creator.txt +49 -0
  628. data/install/config/tools/handbook_creator/templates/command_packets.html.erb +86 -0
  629. data/install/config/tools/handbook_creator/templates/command_toc.html.erb +38 -0
  630. data/install/config/tools/handbook_creator/templates/footer.html.erb +9 -0
  631. data/install/config/tools/handbook_creator/templates/header.html.erb +25 -0
  632. data/install/config/tools/handbook_creator/templates/limits_groups.html.erb +13 -0
  633. data/install/config/tools/handbook_creator/templates/nav.html.erb +27 -0
  634. data/install/config/tools/handbook_creator/templates/overview.html.erb +1 -0
  635. data/install/config/tools/handbook_creator/templates/pdf_cover.html.erb +23 -0
  636. data/install/config/tools/handbook_creator/templates/pdf_footer.html.erb +33 -0
  637. data/install/config/tools/handbook_creator/templates/pdf_header.html.erb +41 -0
  638. data/install/config/tools/handbook_creator/templates/telemetry_packets.html.erb +80 -0
  639. data/install/config/tools/handbook_creator/templates/telemetry_toc.html.erb +38 -0
  640. data/install/config/tools/handbook_creator/templates/title.html.erb +1 -0
  641. data/install/config/tools/launcher/launcher.txt +40 -0
  642. data/install/config/tools/limits_monitor/README.txt +1 -0
  643. data/install/config/tools/opengl_builder/README.txt +1 -0
  644. data/install/config/tools/script_runner/script_runner.txt +3 -0
  645. data/install/config/tools/table_manager/README.txt +1 -0
  646. data/install/config/tools/test_runner/test_runner.txt +8 -0
  647. data/install/config/tools/tlm_extractor/README.txt +1 -0
  648. data/install/config/tools/tlm_grapher/README.txt +1 -0
  649. data/install/config/tools/tlm_viewer/tlm_viewer.txt +5 -0
  650. data/install/lib/user_version.rb +3 -0
  651. data/install/procedures/README.txt +1 -0
  652. data/install/tools/CmdExtractor +16 -0
  653. data/install/tools/CmdExtractor.bat +9 -0
  654. data/install/tools/CmdSender +16 -0
  655. data/install/tools/CmdSender.bat +9 -0
  656. data/install/tools/CmdSequence +16 -0
  657. data/install/tools/CmdSequence.bat +9 -0
  658. data/install/tools/CmdTlmServer +16 -0
  659. data/install/tools/CmdTlmServer.bat +9 -0
  660. data/install/tools/ConfigEditor +16 -0
  661. data/install/tools/ConfigEditor.bat +9 -0
  662. data/install/tools/DataViewer +16 -0
  663. data/install/tools/DataViewer.bat +9 -0
  664. data/install/tools/HandbookCreator +16 -0
  665. data/install/tools/HandbookCreator.bat +9 -0
  666. data/install/tools/Launcher +16 -0
  667. data/install/tools/Launcher.bat +9 -0
  668. data/install/tools/LimitsMonitor +16 -0
  669. data/install/tools/LimitsMonitor.bat +9 -0
  670. data/install/tools/OpenGLBuilder +16 -0
  671. data/install/tools/OpenGLBuilder.bat +9 -0
  672. data/install/tools/PacketViewer +16 -0
  673. data/install/tools/PacketViewer.bat +9 -0
  674. data/install/tools/Replay +16 -0
  675. data/install/tools/Replay.bat +9 -0
  676. data/install/tools/ScriptRunner +16 -0
  677. data/install/tools/ScriptRunner.bat +9 -0
  678. data/install/tools/TableManager +16 -0
  679. data/install/tools/TableManager.bat +9 -0
  680. data/install/tools/TestRunner +16 -0
  681. data/install/tools/TestRunner.bat +9 -0
  682. data/install/tools/TlmExtractor +16 -0
  683. data/install/tools/TlmExtractor.bat +9 -0
  684. data/install/tools/TlmGrapher +16 -0
  685. data/install/tools/TlmGrapher.bat +9 -0
  686. data/install/tools/TlmViewer +16 -0
  687. data/install/tools/TlmViewer.bat +9 -0
  688. data/install/tools/ToolLaunch.bat +72 -0
  689. data/install/tools/mac/CmdExtractor.app/Contents/Info.plist +38 -0
  690. data/install/tools/mac/CmdExtractor.app/Contents/MacOS/CmdExtractor.rb +16 -0
  691. data/install/tools/mac/CmdExtractor.app/Contents/MacOS/main.sh +10 -0
  692. data/install/tools/mac/CmdExtractor.app/Contents/MacOS/tool_launch.rb +38 -0
  693. data/install/tools/mac/CmdExtractor.app/Contents/Resources/appIcon.icns +0 -0
  694. data/install/tools/mac/CmdSender.app/Contents/Info.plist +38 -0
  695. data/install/tools/mac/CmdSender.app/Contents/MacOS/CmdSender.rb +16 -0
  696. data/install/tools/mac/CmdSender.app/Contents/MacOS/main.sh +10 -0
  697. data/install/tools/mac/CmdSender.app/Contents/MacOS/tool_launch.rb +38 -0
  698. data/install/tools/mac/CmdSender.app/Contents/Resources/appIcon.icns +0 -0
  699. data/install/tools/mac/CmdSequence.app/Contents/Info.plist +38 -0
  700. data/install/tools/mac/CmdSequence.app/Contents/MacOS/CmdSequence.rb +16 -0
  701. data/install/tools/mac/CmdSequence.app/Contents/MacOS/main.sh +10 -0
  702. data/install/tools/mac/CmdSequence.app/Contents/MacOS/tool_launch.rb +38 -0
  703. data/install/tools/mac/CmdSequence.app/Contents/Resources/appIcon.icns +0 -0
  704. data/install/tools/mac/CmdTlmServer.app/Contents/Info.plist +38 -0
  705. data/install/tools/mac/CmdTlmServer.app/Contents/MacOS/CmdTlmServer.rb +16 -0
  706. data/install/tools/mac/CmdTlmServer.app/Contents/MacOS/main.sh +10 -0
  707. data/install/tools/mac/CmdTlmServer.app/Contents/MacOS/tool_launch.rb +38 -0
  708. data/install/tools/mac/CmdTlmServer.app/Contents/Resources/appIcon.icns +0 -0
  709. data/install/tools/mac/ConfigEditor.app/Contents/Info.plist +38 -0
  710. data/install/tools/mac/ConfigEditor.app/Contents/MacOS/ConfigEditor.rb +16 -0
  711. data/install/tools/mac/ConfigEditor.app/Contents/MacOS/main.sh +10 -0
  712. data/install/tools/mac/ConfigEditor.app/Contents/MacOS/tool_launch.rb +38 -0
  713. data/install/tools/mac/ConfigEditor.app/Contents/Resources/appIcon.icns +0 -0
  714. data/install/tools/mac/DataViewer.app/Contents/Info.plist +38 -0
  715. data/install/tools/mac/DataViewer.app/Contents/MacOS/DataViewer.rb +16 -0
  716. data/install/tools/mac/DataViewer.app/Contents/MacOS/main.sh +10 -0
  717. data/install/tools/mac/DataViewer.app/Contents/MacOS/tool_launch.rb +38 -0
  718. data/install/tools/mac/DataViewer.app/Contents/Resources/appIcon.icns +0 -0
  719. data/install/tools/mac/HandbookCreator.app/Contents/Info.plist +38 -0
  720. data/install/tools/mac/HandbookCreator.app/Contents/MacOS/HandbookCreator.rb +16 -0
  721. data/install/tools/mac/HandbookCreator.app/Contents/MacOS/main.sh +10 -0
  722. data/install/tools/mac/HandbookCreator.app/Contents/MacOS/tool_launch.rb +38 -0
  723. data/install/tools/mac/HandbookCreator.app/Contents/Resources/appIcon.icns +0 -0
  724. data/install/tools/mac/Launcher.app/Contents/Info.plist +38 -0
  725. data/install/tools/mac/Launcher.app/Contents/MacOS/Launcher.rb +16 -0
  726. data/install/tools/mac/Launcher.app/Contents/MacOS/main.sh +10 -0
  727. data/install/tools/mac/Launcher.app/Contents/MacOS/tool_launch.rb +38 -0
  728. data/install/tools/mac/Launcher.app/Contents/Resources/appIcon.icns +0 -0
  729. data/install/tools/mac/LimitsMonitor.app/Contents/Info.plist +38 -0
  730. data/install/tools/mac/LimitsMonitor.app/Contents/MacOS/LimitsMonitor.rb +16 -0
  731. data/install/tools/mac/LimitsMonitor.app/Contents/MacOS/main.sh +10 -0
  732. data/install/tools/mac/LimitsMonitor.app/Contents/MacOS/tool_launch.rb +38 -0
  733. data/install/tools/mac/LimitsMonitor.app/Contents/Resources/appIcon.icns +0 -0
  734. data/install/tools/mac/OpenGLBuilder.app/Contents/Info.plist +38 -0
  735. data/install/tools/mac/OpenGLBuilder.app/Contents/MacOS/OpenGLBuilder.rb +16 -0
  736. data/install/tools/mac/OpenGLBuilder.app/Contents/MacOS/main.sh +10 -0
  737. data/install/tools/mac/OpenGLBuilder.app/Contents/MacOS/tool_launch.rb +38 -0
  738. data/install/tools/mac/OpenGLBuilder.app/Contents/Resources/appIcon.icns +0 -0
  739. data/install/tools/mac/PacketViewer.app/Contents/Info.plist +38 -0
  740. data/install/tools/mac/PacketViewer.app/Contents/MacOS/PacketViewer.rb +16 -0
  741. data/install/tools/mac/PacketViewer.app/Contents/MacOS/main.sh +10 -0
  742. data/install/tools/mac/PacketViewer.app/Contents/MacOS/tool_launch.rb +38 -0
  743. data/install/tools/mac/PacketViewer.app/Contents/Resources/appIcon.icns +0 -0
  744. data/install/tools/mac/Replay.app/Contents/Info.plist +38 -0
  745. data/install/tools/mac/Replay.app/Contents/MacOS/Replay.rb +16 -0
  746. data/install/tools/mac/Replay.app/Contents/MacOS/main.sh +10 -0
  747. data/install/tools/mac/Replay.app/Contents/MacOS/tool_launch.rb +38 -0
  748. data/install/tools/mac/Replay.app/Contents/Resources/appIcon.icns +0 -0
  749. data/install/tools/mac/ScriptRunner.app/Contents/Info.plist +38 -0
  750. data/install/tools/mac/ScriptRunner.app/Contents/MacOS/ScriptRunner.rb +16 -0
  751. data/install/tools/mac/ScriptRunner.app/Contents/MacOS/main.sh +10 -0
  752. data/install/tools/mac/ScriptRunner.app/Contents/MacOS/tool_launch.rb +38 -0
  753. data/install/tools/mac/ScriptRunner.app/Contents/Resources/appIcon.icns +0 -0
  754. data/install/tools/mac/TableManager.app/Contents/Info.plist +38 -0
  755. data/install/tools/mac/TableManager.app/Contents/MacOS/TableManager.rb +16 -0
  756. data/install/tools/mac/TableManager.app/Contents/MacOS/main.sh +10 -0
  757. data/install/tools/mac/TableManager.app/Contents/MacOS/tool_launch.rb +38 -0
  758. data/install/tools/mac/TableManager.app/Contents/Resources/appIcon.icns +0 -0
  759. data/install/tools/mac/TestRunner.app/Contents/Info.plist +38 -0
  760. data/install/tools/mac/TestRunner.app/Contents/MacOS/TestRunner.rb +16 -0
  761. data/install/tools/mac/TestRunner.app/Contents/MacOS/main.sh +10 -0
  762. data/install/tools/mac/TestRunner.app/Contents/MacOS/tool_launch.rb +38 -0
  763. data/install/tools/mac/TestRunner.app/Contents/Resources/appIcon.icns +0 -0
  764. data/install/tools/mac/TlmExtractor.app/Contents/Info.plist +38 -0
  765. data/install/tools/mac/TlmExtractor.app/Contents/MacOS/TlmExtractor.rb +16 -0
  766. data/install/tools/mac/TlmExtractor.app/Contents/MacOS/main.sh +10 -0
  767. data/install/tools/mac/TlmExtractor.app/Contents/MacOS/tool_launch.rb +38 -0
  768. data/install/tools/mac/TlmExtractor.app/Contents/Resources/appIcon.icns +0 -0
  769. data/install/tools/mac/TlmGrapher.app/Contents/Info.plist +38 -0
  770. data/install/tools/mac/TlmGrapher.app/Contents/MacOS/TlmGrapher.rb +16 -0
  771. data/install/tools/mac/TlmGrapher.app/Contents/MacOS/main.sh +10 -0
  772. data/install/tools/mac/TlmGrapher.app/Contents/MacOS/tool_launch.rb +38 -0
  773. data/install/tools/mac/TlmGrapher.app/Contents/Resources/appIcon.icns +0 -0
  774. data/install/tools/mac/TlmViewer.app/Contents/Info.plist +38 -0
  775. data/install/tools/mac/TlmViewer.app/Contents/MacOS/TlmViewer.rb +16 -0
  776. data/install/tools/mac/TlmViewer.app/Contents/MacOS/main.sh +10 -0
  777. data/install/tools/mac/TlmViewer.app/Contents/MacOS/tool_launch.rb +38 -0
  778. data/install/tools/mac/TlmViewer.app/Contents/Resources/appIcon.icns +0 -0
  779. data/install/tools/tool_launch.rb +38 -0
  780. data/lib/cosmos.rb +63 -0
  781. data/lib/cosmos/ccsds/ccsds_packet.rb +63 -0
  782. data/lib/cosmos/ccsds/ccsds_parser.rb +143 -0
  783. data/lib/cosmos/config/config_parser.rb +508 -0
  784. data/lib/cosmos/config/meta_config_parser.rb +57 -0
  785. data/lib/cosmos/conversions.rb +13 -0
  786. data/lib/cosmos/conversions/conversion.rb +52 -0
  787. data/lib/cosmos/conversions/generic_conversion.rb +67 -0
  788. data/lib/cosmos/conversions/new_packet_log_conversion.rb +52 -0
  789. data/lib/cosmos/conversions/polynomial_conversion.rb +79 -0
  790. data/lib/cosmos/conversions/processor_conversion.rb +56 -0
  791. data/lib/cosmos/conversions/received_count_conversion.rb +33 -0
  792. data/lib/cosmos/conversions/received_time_formatted_conversion.rb +37 -0
  793. data/lib/cosmos/conversions/received_time_seconds_conversion.rb +37 -0
  794. data/lib/cosmos/conversions/segmented_polynomial_conversion.rb +139 -0
  795. data/lib/cosmos/conversions/unix_time_conversion.rb +57 -0
  796. data/lib/cosmos/conversions/unix_time_formatted_conversion.rb +44 -0
  797. data/lib/cosmos/conversions/unix_time_seconds_conversion.rb +44 -0
  798. data/lib/cosmos/core_ext.rb +18 -0
  799. data/lib/cosmos/core_ext/array.rb +397 -0
  800. data/lib/cosmos/core_ext/class.rb +53 -0
  801. data/lib/cosmos/core_ext/cosmos_io.rb +45 -0
  802. data/lib/cosmos/core_ext/exception.rb +52 -0
  803. data/lib/cosmos/core_ext/file.rb +76 -0
  804. data/lib/cosmos/core_ext/hash.rb +28 -0
  805. data/lib/cosmos/core_ext/io.rb +93 -0
  806. data/lib/cosmos/core_ext/kernel.rb +33 -0
  807. data/lib/cosmos/core_ext/math.rb +119 -0
  808. data/lib/cosmos/core_ext/matrix.rb +149 -0
  809. data/lib/cosmos/core_ext/objectspace.rb +27 -0
  810. data/lib/cosmos/core_ext/range.rb +18 -0
  811. data/lib/cosmos/core_ext/socket.rb +32 -0
  812. data/lib/cosmos/core_ext/string.rb +351 -0
  813. data/lib/cosmos/core_ext/stringio.rb +24 -0
  814. data/lib/cosmos/core_ext/time.rb +481 -0
  815. data/lib/cosmos/ext/.keep +0 -0
  816. data/lib/cosmos/gui/choosers/combobox_chooser.rb +141 -0
  817. data/lib/cosmos/gui/choosers/file_chooser.rb +85 -0
  818. data/lib/cosmos/gui/choosers/float_chooser.rb +67 -0
  819. data/lib/cosmos/gui/choosers/integer_chooser.rb +69 -0
  820. data/lib/cosmos/gui/choosers/string_chooser.rb +35 -0
  821. data/lib/cosmos/gui/choosers/telemetry_chooser.rb +326 -0
  822. data/lib/cosmos/gui/choosers/value_chooser.rb +67 -0
  823. data/lib/cosmos/gui/dialogs/about_dialog.rb +166 -0
  824. data/lib/cosmos/gui/dialogs/calendar_dialog.rb +140 -0
  825. data/lib/cosmos/gui/dialogs/cmd_details_dialog.rb +51 -0
  826. data/lib/cosmos/gui/dialogs/cmd_tlm_raw_dialog.rb +163 -0
  827. data/lib/cosmos/gui/dialogs/details_dialog.rb +190 -0
  828. data/lib/cosmos/gui/dialogs/exception_dialog.rb +106 -0
  829. data/lib/cosmos/gui/dialogs/exception_list_dialog.rb +60 -0
  830. data/lib/cosmos/gui/dialogs/find_replace_dialog.rb +272 -0
  831. data/lib/cosmos/gui/dialogs/interface_raw_dialog.rb +143 -0
  832. data/lib/cosmos/gui/dialogs/legal_dialog.rb +183 -0
  833. data/lib/cosmos/gui/dialogs/packet_log_dialog.rb +97 -0
  834. data/lib/cosmos/gui/dialogs/progress_dialog.rb +313 -0
  835. data/lib/cosmos/gui/dialogs/pry_dialog.rb +169 -0
  836. data/lib/cosmos/gui/dialogs/scroll_text_dialog.rb +51 -0
  837. data/lib/cosmos/gui/dialogs/select_dialog.rb +59 -0
  838. data/lib/cosmos/gui/dialogs/set_tlm_dialog.rb +159 -0
  839. data/lib/cosmos/gui/dialogs/splash.rb +145 -0
  840. data/lib/cosmos/gui/dialogs/tlm_details_dialog.rb +201 -0
  841. data/lib/cosmos/gui/dialogs/tlm_edit_dialog.rb +79 -0
  842. data/lib/cosmos/gui/dialogs/tlm_graph_dialog.rb +108 -0
  843. data/lib/cosmos/gui/line_graph/line_graph.rb +482 -0
  844. data/lib/cosmos/gui/line_graph/line_graph_dialog.rb +36 -0
  845. data/lib/cosmos/gui/line_graph/line_graph_drawing.rb +521 -0
  846. data/lib/cosmos/gui/line_graph/line_graph_popups.rb +112 -0
  847. data/lib/cosmos/gui/line_graph/line_graph_scaling.rb +452 -0
  848. data/lib/cosmos/gui/line_graph/line_graph_script.rb +81 -0
  849. data/lib/cosmos/gui/line_graph/lines.rb +304 -0
  850. data/lib/cosmos/gui/line_graph/overview_graph.rb +474 -0
  851. data/lib/cosmos/gui/opengl/earth_model.rb +25 -0
  852. data/lib/cosmos/gui/opengl/gl_bounds.rb +55 -0
  853. data/lib/cosmos/gui/opengl/gl_light.rb +38 -0
  854. data/lib/cosmos/gui/opengl/gl_material.rb +28 -0
  855. data/lib/cosmos/gui/opengl/gl_scene.rb +78 -0
  856. data/lib/cosmos/gui/opengl/gl_shape.rb +150 -0
  857. data/lib/cosmos/gui/opengl/gl_viewer.rb +712 -0
  858. data/lib/cosmos/gui/opengl/gl_viewport.rb +34 -0
  859. data/lib/cosmos/gui/opengl/moon_model.rb +25 -0
  860. data/lib/cosmos/gui/opengl/opengl.rb +8 -0
  861. data/lib/cosmos/gui/opengl/stl_reader.rb +210 -0
  862. data/lib/cosmos/gui/opengl/stl_shape.rb +127 -0
  863. data/lib/cosmos/gui/opengl/texture_mapped_sphere.rb +202 -0
  864. data/lib/cosmos/gui/qt.rb +841 -0
  865. data/lib/cosmos/gui/qt_tool.rb +489 -0
  866. data/lib/cosmos/gui/text/completion.rb +402 -0
  867. data/lib/cosmos/gui/text/completion_line_edit.rb +30 -0
  868. data/lib/cosmos/gui/text/completion_text_edit.rb +194 -0
  869. data/lib/cosmos/gui/text/ruby_editor.rb +463 -0
  870. data/lib/cosmos/gui/utilities/analyze_log.rb +153 -0
  871. data/lib/cosmos/gui/utilities/screenshot.rb +33 -0
  872. data/lib/cosmos/gui/utilities/script_module_gui.rb +364 -0
  873. data/lib/cosmos/gui/widgets/full_text_search_line_edit.rb +171 -0
  874. data/lib/cosmos/gui/widgets/packet_log_frame.rb +344 -0
  875. data/lib/cosmos/gui/widgets/realtime_button_bar.rb +98 -0
  876. data/lib/cosmos/interfaces.rb +21 -0
  877. data/lib/cosmos/interfaces/cmd_tlm_server_interface.rb +134 -0
  878. data/lib/cosmos/interfaces/interface.rb +449 -0
  879. data/lib/cosmos/interfaces/linc_interface.rb +459 -0
  880. data/lib/cosmos/interfaces/protocols/burst_protocol.rb +173 -0
  881. data/lib/cosmos/interfaces/protocols/crc_protocol.rb +141 -0
  882. data/lib/cosmos/interfaces/protocols/fixed_protocol.rb +114 -0
  883. data/lib/cosmos/interfaces/protocols/length_protocol.rb +147 -0
  884. data/lib/cosmos/interfaces/protocols/override_protocol.rb +52 -0
  885. data/lib/cosmos/interfaces/protocols/preidentified_protocol.rb +141 -0
  886. data/lib/cosmos/interfaces/protocols/protocol.rb +60 -0
  887. data/lib/cosmos/interfaces/protocols/template_protocol.rb +240 -0
  888. data/lib/cosmos/interfaces/protocols/terminated_protocol.rb +81 -0
  889. data/lib/cosmos/interfaces/serial_interface.rb +81 -0
  890. data/lib/cosmos/interfaces/simulated_target_interface.rb +140 -0
  891. data/lib/cosmos/interfaces/stream_interface.rb +64 -0
  892. data/lib/cosmos/interfaces/tcpip_client_interface.rb +60 -0
  893. data/lib/cosmos/interfaces/tcpip_server_interface.rb +625 -0
  894. data/lib/cosmos/interfaces/udp_interface.rb +141 -0
  895. data/lib/cosmos/io/buffered_file.rb +101 -0
  896. data/lib/cosmos/io/cosmos_snmp.rb +50 -0
  897. data/lib/cosmos/io/io_multiplexer.rb +71 -0
  898. data/lib/cosmos/io/json_drb.rb +386 -0
  899. data/lib/cosmos/io/json_drb_object.rb +201 -0
  900. data/lib/cosmos/io/json_rpc.rb +365 -0
  901. data/lib/cosmos/io/posix_serial_driver.rb +147 -0
  902. data/lib/cosmos/io/raw_logger.rb +170 -0
  903. data/lib/cosmos/io/raw_logger_pair.rb +71 -0
  904. data/lib/cosmos/io/serial_driver.rb +94 -0
  905. data/lib/cosmos/io/stderr.rb +36 -0
  906. data/lib/cosmos/io/stdout.rb +36 -0
  907. data/lib/cosmos/io/udp_sockets.rb +152 -0
  908. data/lib/cosmos/io/win32_serial_driver.rb +165 -0
  909. data/lib/cosmos/packet_logs.rb +6 -0
  910. data/lib/cosmos/packet_logs/ccsds_log_reader.rb +104 -0
  911. data/lib/cosmos/packet_logs/packet_log_reader.rb +461 -0
  912. data/lib/cosmos/packet_logs/packet_log_writer.rb +341 -0
  913. data/lib/cosmos/packet_logs/packet_log_writer_pair.rb +30 -0
  914. data/lib/cosmos/packets/binary_accessor.rb +1201 -0
  915. data/lib/cosmos/packets/commands.rb +318 -0
  916. data/lib/cosmos/packets/limits.rb +264 -0
  917. data/lib/cosmos/packets/limits_response.rb +42 -0
  918. data/lib/cosmos/packets/packet.rb +994 -0
  919. data/lib/cosmos/packets/packet_config.rb +1393 -0
  920. data/lib/cosmos/packets/packet_item.rb +585 -0
  921. data/lib/cosmos/packets/packet_item_limits.rb +140 -0
  922. data/lib/cosmos/packets/parsers/format_string_parser.rb +59 -0
  923. data/lib/cosmos/packets/parsers/limits_parser.rb +147 -0
  924. data/lib/cosmos/packets/parsers/limits_response_parser.rb +52 -0
  925. data/lib/cosmos/packets/parsers/macro_parser.rb +118 -0
  926. data/lib/cosmos/packets/parsers/packet_item_parser.rb +234 -0
  927. data/lib/cosmos/packets/parsers/packet_parser.rb +131 -0
  928. data/lib/cosmos/packets/parsers/processor_parser.rb +63 -0
  929. data/lib/cosmos/packets/parsers/state_parser.rb +119 -0
  930. data/lib/cosmos/packets/structure.rb +508 -0
  931. data/lib/cosmos/packets/structure_item.rb +292 -0
  932. data/lib/cosmos/packets/telemetry.rb +444 -0
  933. data/lib/cosmos/processors.rb +6 -0
  934. data/lib/cosmos/processors/new_packet_log_processor.rb +39 -0
  935. data/lib/cosmos/processors/processor.rb +76 -0
  936. data/lib/cosmos/processors/statistics_processor.rb +70 -0
  937. data/lib/cosmos/processors/watermark_processor.rb +49 -0
  938. data/lib/cosmos/script.rb +9 -0
  939. data/lib/cosmos/script/api_shared.rb +972 -0
  940. data/lib/cosmos/script/cmd_tlm_server.rb +138 -0
  941. data/lib/cosmos/script/commands.rb +189 -0
  942. data/lib/cosmos/script/extract.rb +139 -0
  943. data/lib/cosmos/script/limits.rb +116 -0
  944. data/lib/cosmos/script/script.rb +76 -0
  945. data/lib/cosmos/script/scripting.rb +144 -0
  946. data/lib/cosmos/script/telemetry.rb +216 -0
  947. data/lib/cosmos/script/tools.rb +97 -0
  948. data/lib/cosmos/streams/serial_stream.rb +150 -0
  949. data/lib/cosmos/streams/stream.rb +54 -0
  950. data/lib/cosmos/streams/tcpip_client_stream.rb +113 -0
  951. data/lib/cosmos/streams/tcpip_socket_stream.rb +186 -0
  952. data/lib/cosmos/system.rb +4 -0
  953. data/lib/cosmos/system/system.rb +778 -0
  954. data/lib/cosmos/system/target.rb +228 -0
  955. data/lib/cosmos/tools/cmd_extractor/cmd_extractor.rb +268 -0
  956. data/lib/cosmos/tools/cmd_sender/cmd_param_table_item_delegate.rb +78 -0
  957. data/lib/cosmos/tools/cmd_sender/cmd_sender.rb +773 -0
  958. data/lib/cosmos/tools/cmd_sender/cmd_sender_text_edit.rb +70 -0
  959. data/lib/cosmos/tools/cmd_sequence/cmd_sequence.rb +652 -0
  960. data/lib/cosmos/tools/cmd_sequence/sequence_item.rb +510 -0
  961. data/lib/cosmos/tools/cmd_sequence/sequence_list.rb +194 -0
  962. data/lib/cosmos/tools/cmd_tlm_server/api.rb +1337 -0
  963. data/lib/cosmos/tools/cmd_tlm_server/background_task.rb +54 -0
  964. data/lib/cosmos/tools/cmd_tlm_server/background_tasks.rb +77 -0
  965. data/lib/cosmos/tools/cmd_tlm_server/cmd_tlm_server.rb +537 -0
  966. data/lib/cosmos/tools/cmd_tlm_server/cmd_tlm_server_config.rb +274 -0
  967. data/lib/cosmos/tools/cmd_tlm_server/cmd_tlm_server_gui.rb +480 -0
  968. data/lib/cosmos/tools/cmd_tlm_server/commanding.rb +121 -0
  969. data/lib/cosmos/tools/cmd_tlm_server/connections.rb +175 -0
  970. data/lib/cosmos/tools/cmd_tlm_server/gui/interfaces_tab.rb +213 -0
  971. data/lib/cosmos/tools/cmd_tlm_server/gui/logging_tab.rb +176 -0
  972. data/lib/cosmos/tools/cmd_tlm_server/gui/packets_tab.rb +151 -0
  973. data/lib/cosmos/tools/cmd_tlm_server/gui/status_tab.rb +255 -0
  974. data/lib/cosmos/tools/cmd_tlm_server/gui/targets_tab.rb +85 -0
  975. data/lib/cosmos/tools/cmd_tlm_server/interface_thread.rb +274 -0
  976. data/lib/cosmos/tools/cmd_tlm_server/interfaces.rb +153 -0
  977. data/lib/cosmos/tools/cmd_tlm_server/limits_groups_background_task.rb +122 -0
  978. data/lib/cosmos/tools/cmd_tlm_server/packet_logging.rb +161 -0
  979. data/lib/cosmos/tools/cmd_tlm_server/router_thread.rb +66 -0
  980. data/lib/cosmos/tools/cmd_tlm_server/routers.rb +134 -0
  981. data/lib/cosmos/tools/config_editor/config_editor.rb +728 -0
  982. data/lib/cosmos/tools/config_editor/config_editor_frame.rb +690 -0
  983. data/lib/cosmos/tools/data_viewer/data_viewer.rb +633 -0
  984. data/lib/cosmos/tools/data_viewer/data_viewer_component.rb +120 -0
  985. data/lib/cosmos/tools/data_viewer/dump_component.rb +40 -0
  986. data/lib/cosmos/tools/handbook_creator/handbook_creator.rb +156 -0
  987. data/lib/cosmos/tools/handbook_creator/handbook_creator_config.rb +382 -0
  988. data/lib/cosmos/tools/launcher/launcher.rb +194 -0
  989. data/lib/cosmos/tools/launcher/launcher_config.rb +256 -0
  990. data/lib/cosmos/tools/launcher/launcher_multitool.rb +40 -0
  991. data/lib/cosmos/tools/launcher/launcher_tool.rb +116 -0
  992. data/lib/cosmos/tools/limits_monitor/limits_monitor.rb +972 -0
  993. data/lib/cosmos/tools/opengl_builder/opengl_builder.rb +416 -0
  994. data/lib/cosmos/tools/opengl_builder/scene_config.rb +118 -0
  995. data/lib/cosmos/tools/packet_viewer/packet_viewer.rb +608 -0
  996. data/lib/cosmos/tools/replay/replay.rb +517 -0
  997. data/lib/cosmos/tools/replay/replay_server.rb +91 -0
  998. data/lib/cosmos/tools/script_runner/script_audit.rb +147 -0
  999. data/lib/cosmos/tools/script_runner/script_runner.rb +979 -0
  1000. data/lib/cosmos/tools/script_runner/script_runner_config.rb +40 -0
  1001. data/lib/cosmos/tools/script_runner/script_runner_frame.rb +1838 -0
  1002. data/lib/cosmos/tools/table_manager/table.rb +61 -0
  1003. data/lib/cosmos/tools/table_manager/table_config.rb +189 -0
  1004. data/lib/cosmos/tools/table_manager/table_item.rb +58 -0
  1005. data/lib/cosmos/tools/table_manager/table_item_parser.rb +46 -0
  1006. data/lib/cosmos/tools/table_manager/table_manager.rb +1152 -0
  1007. data/lib/cosmos/tools/table_manager/table_manager_core.rb +321 -0
  1008. data/lib/cosmos/tools/table_manager/table_parser.rb +75 -0
  1009. data/lib/cosmos/tools/test_runner/results_writer.rb +283 -0
  1010. data/lib/cosmos/tools/test_runner/test.rb +539 -0
  1011. data/lib/cosmos/tools/test_runner/test_runner.rb +1271 -0
  1012. data/lib/cosmos/tools/test_runner/test_runner_chooser.rb +341 -0
  1013. data/lib/cosmos/tools/tlm_extractor/text_item_chooser.rb +60 -0
  1014. data/lib/cosmos/tools/tlm_extractor/tlm_extractor.rb +1152 -0
  1015. data/lib/cosmos/tools/tlm_extractor/tlm_extractor_config.rb +441 -0
  1016. data/lib/cosmos/tools/tlm_extractor/tlm_extractor_processor.rb +60 -0
  1017. data/lib/cosmos/tools/tlm_grapher/data_object_adders/housekeeping_data_object_adder.rb +92 -0
  1018. data/lib/cosmos/tools/tlm_grapher/data_object_adders/singlexy_data_object_adder.rb +44 -0
  1019. data/lib/cosmos/tools/tlm_grapher/data_object_adders/xy_data_object_adder.rb +95 -0
  1020. data/lib/cosmos/tools/tlm_grapher/data_object_editors/data_object_editor.rb +61 -0
  1021. data/lib/cosmos/tools/tlm_grapher/data_object_editors/housekeeping_data_object_editor.rb +222 -0
  1022. data/lib/cosmos/tools/tlm_grapher/data_object_editors/linegraph_data_object_editor.rb +141 -0
  1023. data/lib/cosmos/tools/tlm_grapher/data_object_editors/singlexy_data_object_editor.rb +30 -0
  1024. data/lib/cosmos/tools/tlm_grapher/data_object_editors/xy_data_object_editor.rb +174 -0
  1025. data/lib/cosmos/tools/tlm_grapher/data_objects/data_object.rb +193 -0
  1026. data/lib/cosmos/tools/tlm_grapher/data_objects/housekeeping_data_object.rb +422 -0
  1027. data/lib/cosmos/tools/tlm_grapher/data_objects/linegraph_data_object.rb +176 -0
  1028. data/lib/cosmos/tools/tlm_grapher/data_objects/singlexy_data_object.rb +25 -0
  1029. data/lib/cosmos/tools/tlm_grapher/data_objects/xy_data_object.rb +325 -0
  1030. data/lib/cosmos/tools/tlm_grapher/plot_editors/linegraph_plot_editor.rb +191 -0
  1031. data/lib/cosmos/tools/tlm_grapher/plot_editors/plot_editor.rb +28 -0
  1032. data/lib/cosmos/tools/tlm_grapher/plot_editors/singlexy_plot_editor.rb +30 -0
  1033. data/lib/cosmos/tools/tlm_grapher/plot_editors/xy_plot_editor.rb +59 -0
  1034. data/lib/cosmos/tools/tlm_grapher/plot_gui_objects/linegraph_plot_gui_object.rb +173 -0
  1035. data/lib/cosmos/tools/tlm_grapher/plot_gui_objects/singlexy_plot_gui_object.rb +27 -0
  1036. data/lib/cosmos/tools/tlm_grapher/plot_gui_objects/xy_plot_gui_object.rb +74 -0
  1037. data/lib/cosmos/tools/tlm_grapher/plots/linegraph_plot.rb +209 -0
  1038. data/lib/cosmos/tools/tlm_grapher/plots/plot.rb +69 -0
  1039. data/lib/cosmos/tools/tlm_grapher/plots/singlexy_plot.rb +20 -0
  1040. data/lib/cosmos/tools/tlm_grapher/plots/xy_plot.rb +61 -0
  1041. data/lib/cosmos/tools/tlm_grapher/tabbed_plots/overview_tabbed_plots.rb +1291 -0
  1042. data/lib/cosmos/tools/tlm_grapher/tabbed_plots_tool/tabbed_plots_config.rb +451 -0
  1043. data/lib/cosmos/tools/tlm_grapher/tabbed_plots_tool/tabbed_plots_data_object_editor.rb +107 -0
  1044. data/lib/cosmos/tools/tlm_grapher/tabbed_plots_tool/tabbed_plots_logfile_thread.rb +114 -0
  1045. data/lib/cosmos/tools/tlm_grapher/tabbed_plots_tool/tabbed_plots_plot_editor.rb +101 -0
  1046. data/lib/cosmos/tools/tlm_grapher/tabbed_plots_tool/tabbed_plots_realtime_thread.rb +78 -0
  1047. data/lib/cosmos/tools/tlm_grapher/tabbed_plots_tool/tabbed_plots_tab.rb +57 -0
  1048. data/lib/cosmos/tools/tlm_grapher/tabbed_plots_tool/tabbed_plots_tool.rb +1004 -0
  1049. data/lib/cosmos/tools/tlm_grapher/tlm_grapher.rb +103 -0
  1050. data/lib/cosmos/tools/tlm_viewer/screen.rb +502 -0
  1051. data/lib/cosmos/tools/tlm_viewer/tlm_viewer.rb +571 -0
  1052. data/lib/cosmos/tools/tlm_viewer/tlm_viewer_config.rb +293 -0
  1053. data/lib/cosmos/tools/tlm_viewer/widgets.rb +61 -0
  1054. data/lib/cosmos/tools/tlm_viewer/widgets/aging_widget.rb +110 -0
  1055. data/lib/cosmos/tools/tlm_viewer/widgets/array_widget.rb +66 -0
  1056. data/lib/cosmos/tools/tlm_viewer/widgets/block_widget.rb +57 -0
  1057. data/lib/cosmos/tools/tlm_viewer/widgets/button_widget.rb +39 -0
  1058. data/lib/cosmos/tools/tlm_viewer/widgets/canvas_clickable.rb +33 -0
  1059. data/lib/cosmos/tools/tlm_viewer/widgets/canvas_widget.rb +70 -0
  1060. data/lib/cosmos/tools/tlm_viewer/widgets/canvasdot_widget.rb +77 -0
  1061. data/lib/cosmos/tools/tlm_viewer/widgets/canvasimage_widget.rb +43 -0
  1062. data/lib/cosmos/tools/tlm_viewer/widgets/canvasimagevalue_widget.rb +59 -0
  1063. data/lib/cosmos/tools/tlm_viewer/widgets/canvaslabel_widget.rb +44 -0
  1064. data/lib/cosmos/tools/tlm_viewer/widgets/canvaslabelvalue_widget.rb +54 -0
  1065. data/lib/cosmos/tools/tlm_viewer/widgets/canvasline_widget.rb +53 -0
  1066. data/lib/cosmos/tools/tlm_viewer/widgets/canvaslinevalue_widget.rb +63 -0
  1067. data/lib/cosmos/tools/tlm_viewer/widgets/canvasvalue_widget.rb +123 -0
  1068. data/lib/cosmos/tools/tlm_viewer/widgets/checkbutton_widget.rb +38 -0
  1069. data/lib/cosmos/tools/tlm_viewer/widgets/combobox_widget.rb +30 -0
  1070. data/lib/cosmos/tools/tlm_viewer/widgets/formatfontvalue_widget.rb +31 -0
  1071. data/lib/cosmos/tools/tlm_viewer/widgets/formatvalue_widget.rb +35 -0
  1072. data/lib/cosmos/tools/tlm_viewer/widgets/horizontal_widget.rb +27 -0
  1073. data/lib/cosmos/tools/tlm_viewer/widgets/horizontalbox_widget.rb +31 -0
  1074. data/lib/cosmos/tools/tlm_viewer/widgets/horizontalline_widget.rb +26 -0
  1075. data/lib/cosmos/tools/tlm_viewer/widgets/label_widget.rb +29 -0
  1076. data/lib/cosmos/tools/tlm_viewer/widgets/labelformatvalue_widget.rb +39 -0
  1077. data/lib/cosmos/tools/tlm_viewer/widgets/labelprogressbar_widget.rb +38 -0
  1078. data/lib/cosmos/tools/tlm_viewer/widgets/labeltrendlimitsbar_widget.rb +38 -0
  1079. data/lib/cosmos/tools/tlm_viewer/widgets/labelvalue_widget.rb +57 -0
  1080. data/lib/cosmos/tools/tlm_viewer/widgets/labelvaluedesc_widget.rb +42 -0
  1081. data/lib/cosmos/tools/tlm_viewer/widgets/labelvaluelimitsbar_widget.rb +37 -0
  1082. data/lib/cosmos/tools/tlm_viewer/widgets/labelvaluelimitscolumn_widget.rb +38 -0
  1083. data/lib/cosmos/tools/tlm_viewer/widgets/labelvaluerangebar_widget.rb +37 -0
  1084. data/lib/cosmos/tools/tlm_viewer/widgets/labelvaluerangecolumn_widget.rb +39 -0
  1085. data/lib/cosmos/tools/tlm_viewer/widgets/layout_widget.rb +34 -0
  1086. data/lib/cosmos/tools/tlm_viewer/widgets/limits_widget.rb +113 -0
  1087. data/lib/cosmos/tools/tlm_viewer/widgets/limitsbar_widget.rb +116 -0
  1088. data/lib/cosmos/tools/tlm_viewer/widgets/limitscolor_widget.rb +102 -0
  1089. data/lib/cosmos/tools/tlm_viewer/widgets/limitscolumn_widget.rb +116 -0
  1090. data/lib/cosmos/tools/tlm_viewer/widgets/linegraph_widget.rb +63 -0
  1091. data/lib/cosmos/tools/tlm_viewer/widgets/matrixbycolumns_widget.rb +58 -0
  1092. data/lib/cosmos/tools/tlm_viewer/widgets/multi_widget.rb +116 -0
  1093. data/lib/cosmos/tools/tlm_viewer/widgets/progressbar_widget.rb +34 -0
  1094. data/lib/cosmos/tools/tlm_viewer/widgets/radiobutton_widget.rb +38 -0
  1095. data/lib/cosmos/tools/tlm_viewer/widgets/rangebar_widget.rb +65 -0
  1096. data/lib/cosmos/tools/tlm_viewer/widgets/rangecolumn_widget.rb +65 -0
  1097. data/lib/cosmos/tools/tlm_viewer/widgets/screenshotbutton_widget.rb +34 -0
  1098. data/lib/cosmos/tools/tlm_viewer/widgets/scrollwindow_widget.rb +35 -0
  1099. data/lib/cosmos/tools/tlm_viewer/widgets/sectionheader_widget.rb +33 -0
  1100. data/lib/cosmos/tools/tlm_viewer/widgets/spacer_widget.rb +55 -0
  1101. data/lib/cosmos/tools/tlm_viewer/widgets/tabbook_widget.rb +26 -0
  1102. data/lib/cosmos/tools/tlm_viewer/widgets/tabitem_widget.rb +28 -0
  1103. data/lib/cosmos/tools/tlm_viewer/widgets/textbox_widget.rb +47 -0
  1104. data/lib/cosmos/tools/tlm_viewer/widgets/textfield_widget.rb +26 -0
  1105. data/lib/cosmos/tools/tlm_viewer/widgets/timegraph_widget.rb +91 -0
  1106. data/lib/cosmos/tools/tlm_viewer/widgets/title_widget.rb +27 -0
  1107. data/lib/cosmos/tools/tlm_viewer/widgets/trendbar_widget.rb +130 -0
  1108. data/lib/cosmos/tools/tlm_viewer/widgets/trendlimitsbar_widget.rb +46 -0
  1109. data/lib/cosmos/tools/tlm_viewer/widgets/value_widget.rb +43 -0
  1110. data/lib/cosmos/tools/tlm_viewer/widgets/valuelimitsbar_widget.rb +37 -0
  1111. data/lib/cosmos/tools/tlm_viewer/widgets/valuelimitscolumn_widget.rb +37 -0
  1112. data/lib/cosmos/tools/tlm_viewer/widgets/valuerangebar_widget.rb +37 -0
  1113. data/lib/cosmos/tools/tlm_viewer/widgets/valuerangecolumn_widget.rb +37 -0
  1114. data/lib/cosmos/tools/tlm_viewer/widgets/vertical_widget.rb +36 -0
  1115. data/lib/cosmos/tools/tlm_viewer/widgets/verticalbox_widget.rb +38 -0
  1116. data/lib/cosmos/tools/tlm_viewer/widgets/widget.rb +257 -0
  1117. data/lib/cosmos/top_level.rb +790 -0
  1118. data/lib/cosmos/utilities.rb +11 -0
  1119. data/lib/cosmos/utilities/crc.rb +268 -0
  1120. data/lib/cosmos/utilities/csv.rb +137 -0
  1121. data/lib/cosmos/utilities/logger.rb +137 -0
  1122. data/lib/cosmos/utilities/low_fragmentation_array.rb +19 -0
  1123. data/lib/cosmos/utilities/message_log.rb +79 -0
  1124. data/lib/cosmos/utilities/quaternion.rb +258 -0
  1125. data/lib/cosmos/utilities/ruby_lex_utils.rb +313 -0
  1126. data/lib/cosmos/utilities/simulated_target.rb +100 -0
  1127. data/lib/cosmos/utilities/sleeper.rb +44 -0
  1128. data/lib/cosmos/version.rb +12 -0
  1129. data/lib/cosmos/win32/excel.rb +66 -0
  1130. data/lib/cosmos/win32/win32.rb +387 -0
  1131. data/lib/cosmos/win32/win32_main.rb +325 -0
  1132. data/roodi.yml +24 -0
  1133. data/run_gui_tests.bat +44 -0
  1134. data/spec/ccsds/ccsds_packet_spec.rb +67 -0
  1135. data/spec/ccsds/ccsds_parser_spec.rb +148 -0
  1136. data/spec/config/config_parser_spec.rb +353 -0
  1137. data/spec/conversions/conversion_spec.rb +31 -0
  1138. data/spec/conversions/generic_conversion_spec.rb +45 -0
  1139. data/spec/conversions/new_packet_log_conversion_spec.rb +39 -0
  1140. data/spec/conversions/polynomial_conversion_spec.rb +40 -0
  1141. data/spec/conversions/processor_conversion_spec.rb +45 -0
  1142. data/spec/conversions/received_count_conversion_spec.rb +43 -0
  1143. data/spec/conversions/received_time_formatted_conversion_spec.rb +49 -0
  1144. data/spec/conversions/received_time_seconds_conversion_spec.rb +50 -0
  1145. data/spec/conversions/segmented_polynomial_conversion_spec.rb +51 -0
  1146. data/spec/conversions/unix_time_formatted_conversion_spec.rb +74 -0
  1147. data/spec/conversions/unix_time_seconds_conversion_spec.rb +76 -0
  1148. data/spec/core_ext/array_spec.rb +247 -0
  1149. data/spec/core_ext/class_spec.rb +36 -0
  1150. data/spec/core_ext/cosmos_io_spec.rb +77 -0
  1151. data/spec/core_ext/exception_spec.rb +91 -0
  1152. data/spec/core_ext/file_spec.rb +72 -0
  1153. data/spec/core_ext/hash_spec.rb +24 -0
  1154. data/spec/core_ext/io_spec.rb +46 -0
  1155. data/spec/core_ext/kernel_spec.rb +54 -0
  1156. data/spec/core_ext/math_spec.rb +116 -0
  1157. data/spec/core_ext/matrix_spec.rb +127 -0
  1158. data/spec/core_ext/objectspace_spec.rb +32 -0
  1159. data/spec/core_ext/range_spec.rb +21 -0
  1160. data/spec/core_ext/socket_spec.rb +32 -0
  1161. data/spec/core_ext/string_spec.rb +239 -0
  1162. data/spec/core_ext/stringio_spec.rb +21 -0
  1163. data/spec/core_ext/time_spec.rb +220 -0
  1164. data/spec/gui/line_graph/line_clip_spec.rb +324 -0
  1165. data/spec/gui/qt_spec.rb +104 -0
  1166. data/spec/install/config/system/system.txt +27 -0
  1167. data/spec/install/config/targets/INST/cmd_tlm/inst_cmd_linc.txt +30 -0
  1168. data/spec/install/config/targets/INST/cmd_tlm/inst_cmds.txt +111 -0
  1169. data/spec/install/config/targets/INST/cmd_tlm/inst_tlm.txt +236 -0
  1170. data/spec/install/config/targets/INST/cmd_tlm/inst_tlm_linc.txt +25 -0
  1171. data/spec/install/config/targets/INST/cmd_tlm_server.txt +5 -0
  1172. data/spec/install/config/targets/INST/lib/sim_inst.rb +305 -0
  1173. data/spec/install/config/targets/INST/target.txt +10 -0
  1174. data/spec/install/config/targets/SYSTEM/cmd_tlm/limits_groups.txt +7 -0
  1175. data/spec/install/config/targets/SYSTEM/cmd_tlm/meta_tlm.txt +10 -0
  1176. data/spec/install/config/targets/SYSTEM/cmd_tlm/system_cmds.txt +41 -0
  1177. data/spec/install/config/targets/SYSTEM/cmd_tlm/system_tlm.txt +7 -0
  1178. data/spec/install/config/targets/SYSTEM/cmd_tlm_server.txt +6 -0
  1179. data/spec/install/config/targets/SYSTEM/screens/status.txt +12 -0
  1180. data/spec/install/config/targets/SYSTEM/target.txt +12 -0
  1181. data/spec/install/lib/README.txt +1 -0
  1182. data/spec/interfaces/cmd_tlm_server_interface_spec.rb +146 -0
  1183. data/spec/interfaces/interface_spec.rb +514 -0
  1184. data/spec/interfaces/linc_interface_spec.rb +248 -0
  1185. data/spec/interfaces/protocols/burst_protocol_spec.rb +300 -0
  1186. data/spec/interfaces/protocols/crc_protocol_spec.rb +709 -0
  1187. data/spec/interfaces/protocols/fixed_protocol_spec.rb +119 -0
  1188. data/spec/interfaces/protocols/length_protocol_spec.rb +499 -0
  1189. data/spec/interfaces/protocols/override_protocol_spec.rb +158 -0
  1190. data/spec/interfaces/protocols/preidentified_protocol_spec.rb +149 -0
  1191. data/spec/interfaces/protocols/template_protocol_spec.rb +322 -0
  1192. data/spec/interfaces/protocols/terminated_protocol_spec.rb +174 -0
  1193. data/spec/interfaces/serial_interface_spec.rb +57 -0
  1194. data/spec/interfaces/simulated_target_interface_spec.rb +128 -0
  1195. data/spec/interfaces/tcpip_client_interface_spec.rb +60 -0
  1196. data/spec/interfaces/tcpip_server_interface_spec.rb +157 -0
  1197. data/spec/interfaces/udp_interface_spec.rb +246 -0
  1198. data/spec/io/buffered_file_spec.rb +113 -0
  1199. data/spec/io/io_multiplexer_spec.rb +102 -0
  1200. data/spec/io/json_drb_object_spec.rb +119 -0
  1201. data/spec/io/json_drb_spec.rb +297 -0
  1202. data/spec/io/json_rpc_spec.rb +264 -0
  1203. data/spec/io/raw_logger_pair_spec.rb +76 -0
  1204. data/spec/io/raw_logger_spec.rb +137 -0
  1205. data/spec/io/serial_driver_spec.rb +62 -0
  1206. data/spec/io/stderr_spec.rb +32 -0
  1207. data/spec/io/stdout_spec.rb +32 -0
  1208. data/spec/io/udp_sockets_spec.rb +99 -0
  1209. data/spec/io/win32_serial_driver_spec.rb +91 -0
  1210. data/spec/packet_logs/packet_log_reader_spec.rb +553 -0
  1211. data/spec/packet_logs/packet_log_writer_pair_spec.rb +30 -0
  1212. data/spec/packet_logs/packet_log_writer_spec.rb +227 -0
  1213. data/spec/packets/binary_accessor_spec.rb +2326 -0
  1214. data/spec/packets/commands_spec.rb +379 -0
  1215. data/spec/packets/limits_response_spec.rb +25 -0
  1216. data/spec/packets/limits_spec.rb +344 -0
  1217. data/spec/packets/packet_config_spec.rb +960 -0
  1218. data/spec/packets/packet_item_limits_spec.rb +188 -0
  1219. data/spec/packets/packet_item_spec.rb +386 -0
  1220. data/spec/packets/packet_spec.rb +1456 -0
  1221. data/spec/packets/parsers/format_string_parser_spec.rb +133 -0
  1222. data/spec/packets/parsers/limits_parser_spec.rb +293 -0
  1223. data/spec/packets/parsers/limits_response_parser_spec.rb +149 -0
  1224. data/spec/packets/parsers/macro_parser_spec.rb +220 -0
  1225. data/spec/packets/parsers/packet_item_parser_spec.rb +366 -0
  1226. data/spec/packets/parsers/packet_parser_spec.rb +99 -0
  1227. data/spec/packets/parsers/processor_parser_spec.rb +114 -0
  1228. data/spec/packets/parsers/state_parser_spec.rb +189 -0
  1229. data/spec/packets/structure_item_spec.rb +213 -0
  1230. data/spec/packets/structure_spec.rb +565 -0
  1231. data/spec/packets/telemetry_spec.rb +578 -0
  1232. data/spec/processors/new_packet_log_processor_spec.rb +39 -0
  1233. data/spec/processors/processor_spec.rb +55 -0
  1234. data/spec/processors/statistics_processor_spec.rb +60 -0
  1235. data/spec/processors/watermark_processor_spec.rb +51 -0
  1236. data/spec/script/cmd_tlm_server_spec.rb +176 -0
  1237. data/spec/script/commands_disconnect_spec.rb +270 -0
  1238. data/spec/script/commands_spec.rb +303 -0
  1239. data/spec/script/extract_spec.rb +158 -0
  1240. data/spec/script/limits_spec.rb +153 -0
  1241. data/spec/script/script_spec.rb +90 -0
  1242. data/spec/script/scripting_spec.rb +745 -0
  1243. data/spec/script/telemetry_spec.rb +176 -0
  1244. data/spec/script/tools_spec.rb +134 -0
  1245. data/spec/spec_helper.rb +225 -0
  1246. data/spec/streams/serial_stream_spec.rb +122 -0
  1247. data/spec/streams/stream_spec.rb +30 -0
  1248. data/spec/streams/tcpip_client_stream_spec.rb +65 -0
  1249. data/spec/streams/tcpip_socket_stream_spec.rb +226 -0
  1250. data/spec/system/system_spec.rb +891 -0
  1251. data/spec/system/target_spec.rb +304 -0
  1252. data/spec/tools/cmd_tlm_server/api_spec.rb +1123 -0
  1253. data/spec/tools/cmd_tlm_server/background_task_spec.rb +44 -0
  1254. data/spec/tools/cmd_tlm_server/background_tasks_spec.rb +227 -0
  1255. data/spec/tools/cmd_tlm_server/cmd_tlm_server_config_spec.rb +610 -0
  1256. data/spec/tools/cmd_tlm_server/cmd_tlm_server_spec.rb +431 -0
  1257. data/spec/tools/cmd_tlm_server/commanding_spec.rb +151 -0
  1258. data/spec/tools/cmd_tlm_server/connections_spec.rb +235 -0
  1259. data/spec/tools/cmd_tlm_server/interface_thread_spec.rb +401 -0
  1260. data/spec/tools/cmd_tlm_server/interfaces_spec.rb +252 -0
  1261. data/spec/tools/cmd_tlm_server/limits_groups_background_task_spec.rb +145 -0
  1262. data/spec/tools/cmd_tlm_server/packet_logging_spec.rb +143 -0
  1263. data/spec/tools/cmd_tlm_server/router_thread_spec.rb +191 -0
  1264. data/spec/tools/cmd_tlm_server/routers_spec.rb +223 -0
  1265. data/spec/tools/launcher/launcher_config_spec.rb +474 -0
  1266. data/spec/tools/table_manager/table_config_spec.rb +226 -0
  1267. data/spec/tools/table_manager/table_item_parser_spec.rb +61 -0
  1268. data/spec/tools/table_manager/table_item_spec.rb +57 -0
  1269. data/spec/tools/table_manager/table_parser_spec.rb +96 -0
  1270. data/spec/tools/table_manager/table_spec.rb +90 -0
  1271. data/spec/tools/table_manager/tablemanager_core_spec.rb +556 -0
  1272. data/spec/top_level/top_level_spec.rb +373 -0
  1273. data/spec/utilities/crc_spec.rb +45 -0
  1274. data/spec/utilities/csv_spec.rb +139 -0
  1275. data/spec/utilities/logger_spec.rb +102 -0
  1276. data/spec/utilities/message_log_spec.rb +89 -0
  1277. data/spec/utilities/quaternion_spec.rb +107 -0
  1278. data/spec/utilities/ruby_lex_utils_spec.rb +86 -0
  1279. data/tasks/gemfile_stats.rake +79 -0
  1280. data/tasks/manifest.rake +22 -0
  1281. data/tasks/spec.rake +23 -0
  1282. data/test/benchmarks/binary_accessor_benchmark.rb +14 -0
  1283. data/test/benchmarks/gsub_benchmark.rb +152 -0
  1284. data/test/benchmarks/is_a_benchmark.rb +34 -0
  1285. data/test/performance/PACKETS.bat +1 -0
  1286. data/test/performance/Rakefile +77 -0
  1287. data/test/performance/THREADS.bat +1 -0
  1288. data/test/performance/config/data/attitude.bin +0 -0
  1289. data/test/performance/config/data/crc.txt +196 -0
  1290. data/test/performance/config/data/diamond.STL +58 -0
  1291. data/test/performance/config/data/groundoff.gif +0 -0
  1292. data/test/performance/config/data/groundon.gif +0 -0
  1293. data/test/performance/config/data/hselectoff.gif +0 -0
  1294. data/test/performance/config/data/hselecton.gif +0 -0
  1295. data/test/performance/config/data/hswitchoff.gif +0 -0
  1296. data/test/performance/config/data/hswitchon.gif +0 -0
  1297. data/test/performance/config/data/meta_init.txt +4 -0
  1298. data/test/performance/config/data/position.bin +0 -0
  1299. data/test/performance/config/data/poweroff.gif +0 -0
  1300. data/test/performance/config/data/poweron.gif +0 -0
  1301. data/test/performance/config/data/satellite.gif +0 -0
  1302. data/test/performance/config/data/tada.wav +0 -0
  1303. data/test/performance/config/data/vswitchoff.gif +0 -0
  1304. data/test/performance/config/data/vswitchon.gif +0 -0
  1305. data/test/performance/config/system/system_packets.txt +38 -0
  1306. data/test/performance/config/system/system_threads.txt +58 -0
  1307. data/test/performance/config/targets/COSMOS/cmd_tlm/cosmos_server_cmds.txt +46 -0
  1308. data/test/performance/config/targets/COSMOS/cmd_tlm/cosmos_server_tlm.txt +15 -0
  1309. data/test/performance/config/targets/COSMOS/cmd_tlm_server.txt +6 -0
  1310. data/test/performance/config/targets/COSMOS/screens/limits_change.txt +20 -0
  1311. data/test/performance/config/targets/COSMOS/screens/version.txt +19 -0
  1312. data/test/performance/config/targets/COSMOS/target.txt +11 -0
  1313. data/test/performance/config/targets/PACKET/cmd_tlm/packet_cmds.txt +20 -0
  1314. data/test/performance/config/targets/PACKET/cmd_tlm/packet_tlm.txt +98 -0
  1315. data/test/performance/config/targets/PACKET/cmd_tlm_server.txt +6 -0
  1316. data/test/performance/config/targets/PACKET/lib/packet_interface.rb +22 -0
  1317. data/test/performance/config/targets/PACKET/lib/packet_limits_response.rb +24 -0
  1318. data/test/performance/config/targets/PACKET/screens/status.txt +25 -0
  1319. data/test/performance/config/targets/PACKET/target.txt +28 -0
  1320. data/test/performance/config/targets/SYSTEM/screens/status.txt +12 -0
  1321. data/test/performance/config/targets/THREAD/cmd_tlm/thread_cmds.txt +17 -0
  1322. data/test/performance/config/targets/THREAD/cmd_tlm/thread_tlm.txt +18 -0
  1323. data/test/performance/config/targets/THREAD/cmd_tlm_server.txt +6 -0
  1324. data/test/performance/config/targets/THREAD/lib/thread_interface.rb +22 -0
  1325. data/test/performance/config/targets/THREAD/screens/status.txt +25 -0
  1326. data/test/performance/config/targets/THREAD/target.txt +7 -0
  1327. data/test/performance/config/tools/cmd_tlm_server/cmd_tlm_server_packets.txt +28 -0
  1328. data/test/performance/config/tools/cmd_tlm_server/cmd_tlm_server_threads.txt +68 -0
  1329. data/test/performance/config/tools/data_viewer/data_viewer.txt +11 -0
  1330. data/test/performance/config/tools/handbook_creator/default_toc.xsl +59 -0
  1331. data/test/performance/config/tools/handbook_creator/handbook_creator.txt +66 -0
  1332. data/test/performance/config/tools/handbook_creator/templates/command_packets.html.erb +86 -0
  1333. data/test/performance/config/tools/handbook_creator/templates/command_toc.html.erb +38 -0
  1334. data/test/performance/config/tools/handbook_creator/templates/footer.html.erb +9 -0
  1335. data/test/performance/config/tools/handbook_creator/templates/header.html.erb +25 -0
  1336. data/test/performance/config/tools/handbook_creator/templates/limits_groups.html.erb +13 -0
  1337. data/test/performance/config/tools/handbook_creator/templates/nav.html.erb +27 -0
  1338. data/test/performance/config/tools/handbook_creator/templates/overview.html.erb +1 -0
  1339. data/test/performance/config/tools/handbook_creator/templates/pdf_cover.html.erb +23 -0
  1340. data/test/performance/config/tools/handbook_creator/templates/pdf_footer.html.erb +33 -0
  1341. data/test/performance/config/tools/handbook_creator/templates/pdf_header.html.erb +41 -0
  1342. data/test/performance/config/tools/handbook_creator/templates/telemetry_packets.html.erb +80 -0
  1343. data/test/performance/config/tools/handbook_creator/templates/telemetry_toc.html.erb +38 -0
  1344. data/test/performance/config/tools/handbook_creator/templates/title.html.erb +1 -0
  1345. data/test/performance/config/tools/launcher/launcher_packets.txt +34 -0
  1346. data/test/performance/config/tools/launcher/launcher_threads.txt +83 -0
  1347. data/test/performance/config/tools/limits_monitor/README.txt +1 -0
  1348. data/test/performance/config/tools/opengl_builder/README.txt +1 -0
  1349. data/test/performance/config/tools/script_runner/script_runner.txt +3 -0
  1350. data/test/performance/config/tools/table_manager/ConfigTables_def.txt +8 -0
  1351. data/test/performance/config/tools/table_manager/ExampleTableDefinition.txt +24 -0
  1352. data/test/performance/config/tools/table_manager/MCConfigurationTable_fsw1_def.txt +25 -0
  1353. data/test/performance/config/tools/table_manager/MCConfigurationTable_fsw2_def.txt +25 -0
  1354. data/test/performance/config/tools/table_manager/PPSSelectionTable_def.txt +8 -0
  1355. data/test/performance/config/tools/table_manager/TLMMonitoringTable_def.txt +248 -0
  1356. data/test/performance/config/tools/test_runner/test_runner.txt +17 -0
  1357. data/test/performance/config/tools/tlm_extractor/tlm_extractor.txt +13 -0
  1358. data/test/performance/config/tools/tlm_extractor/tlm_extractor2.txt +2 -0
  1359. data/test/performance/config/tools/tlm_extractor/tlm_extractor3.txt +2 -0
  1360. data/test/performance/config/tools/tlm_extractor/tlm_extractor4.txt +2 -0
  1361. data/test/performance/config/tools/tlm_grapher/README.txt +1 -0
  1362. data/test/performance/config/tools/tlm_grapher/tlm_grapher.txt +204 -0
  1363. data/test/performance/config/tools/tlm_viewer/tlm_viewer.txt +13 -0
  1364. data/test/performance/lib/packet_target.rb +126 -0
  1365. data/test/performance/lib/thread_target.rb +120 -0
  1366. data/test/performance/lib/user_version.rb +3 -0
  1367. data/test/performance/outputs/handbooks/README.txt +1 -0
  1368. data/test/performance/outputs/logs/README.txt +1 -0
  1369. data/test/performance/outputs/saved_config/README.txt +1 -0
  1370. data/test/performance/outputs/tables/README.txt +1 -0
  1371. data/test/performance/outputs/tmp/README.txt +1 -0
  1372. data/test/performance/procedures/checks.rb +11 -0
  1373. data/test/performance/procedures/clear_util.rb +7 -0
  1374. data/test/performance/procedures/collect.rb +18 -0
  1375. data/test/performance/procedures/collect_util.rb +14 -0
  1376. data/test/performance/procedures/cosmos_api_test.rb +293 -0
  1377. data/test/performance/procedures/disconnect.rb +29 -0
  1378. data/test/performance/procedures/example_test.rb +182 -0
  1379. data/test/performance/procedures/plot_test.rb +8 -0
  1380. data/test/performance/procedures/procedure.rb +3 -0
  1381. data/test/performance/procedures/run_example_test.rb +3 -0
  1382. data/test/performance/procedures/test.rb +51 -0
  1383. data/test/performance/tools/CmdExtractor +14 -0
  1384. data/test/performance/tools/CmdExtractor.bat +59 -0
  1385. data/test/performance/tools/CmdSender +14 -0
  1386. data/test/performance/tools/CmdSender.bat +59 -0
  1387. data/test/performance/tools/CmdTlmServer +16 -0
  1388. data/test/performance/tools/CmdTlmServer.bat +59 -0
  1389. data/test/performance/tools/CmdTlmServerMemProf +20 -0
  1390. data/test/performance/tools/CmdTlmServerMemProf.bat +59 -0
  1391. data/test/performance/tools/DataViewer +14 -0
  1392. data/test/performance/tools/DataViewer.bat +59 -0
  1393. data/test/performance/tools/HandbookCreator +14 -0
  1394. data/test/performance/tools/HandbookCreator.bat +61 -0
  1395. data/test/performance/tools/Launcher +14 -0
  1396. data/test/performance/tools/Launcher.bat +59 -0
  1397. data/test/performance/tools/LimitsMonitor +14 -0
  1398. data/test/performance/tools/LimitsMonitor.bat +59 -0
  1399. data/test/performance/tools/OpenGLBuilder +14 -0
  1400. data/test/performance/tools/OpenGLBuilder.bat +59 -0
  1401. data/test/performance/tools/PacketTarget +14 -0
  1402. data/test/performance/tools/PacketTarget.bat +59 -0
  1403. data/test/performance/tools/PacketViewer +14 -0
  1404. data/test/performance/tools/PacketViewer.bat +59 -0
  1405. data/test/performance/tools/Replay +14 -0
  1406. data/test/performance/tools/Replay.bat +59 -0
  1407. data/test/performance/tools/ScpiTarget +14 -0
  1408. data/test/performance/tools/ScpiTarget.bat +59 -0
  1409. data/test/performance/tools/ScriptRunner +14 -0
  1410. data/test/performance/tools/ScriptRunner.bat +59 -0
  1411. data/test/performance/tools/TableManager +14 -0
  1412. data/test/performance/tools/TableManager.bat +59 -0
  1413. data/test/performance/tools/TestRunner +14 -0
  1414. data/test/performance/tools/TestRunner.bat +59 -0
  1415. data/test/performance/tools/ThreadTarget +14 -0
  1416. data/test/performance/tools/ThreadTarget.bat +59 -0
  1417. data/test/performance/tools/TlmExtractor +14 -0
  1418. data/test/performance/tools/TlmExtractor.bat +59 -0
  1419. data/test/performance/tools/TlmGrapher +14 -0
  1420. data/test/performance/tools/TlmGrapher.bat +59 -0
  1421. data/test/performance/tools/TlmGrapherMemProf +19 -0
  1422. data/test/performance/tools/TlmGrapherMemProf.bat +59 -0
  1423. data/test/performance/tools/TlmViewer +14 -0
  1424. data/test/performance/tools/TlmViewer.bat +59 -0
  1425. data/test/performance/tools/TlmViewerMemProf +19 -0
  1426. data/test/performance/tools/TlmViewerMemProf.bat +59 -0
  1427. data/test/performance/tools/mac/CmdExtractor.app/Contents/Info.plist +38 -0
  1428. data/test/performance/tools/mac/CmdExtractor.app/Contents/MacOS/CmdExtractor.rb +15 -0
  1429. data/test/performance/tools/mac/CmdExtractor.app/Contents/MacOS/main.sh +6 -0
  1430. data/test/performance/tools/mac/CmdExtractor.app/Contents/Resources/appIcon.icns +0 -0
  1431. data/test/performance/tools/mac/CmdSender.app/Contents/Info.plist +38 -0
  1432. data/test/performance/tools/mac/CmdSender.app/Contents/MacOS/CmdSender.rb +15 -0
  1433. data/test/performance/tools/mac/CmdSender.app/Contents/MacOS/main.sh +6 -0
  1434. data/test/performance/tools/mac/CmdSender.app/Contents/Resources/appIcon.icns +0 -0
  1435. data/test/performance/tools/mac/CmdTlmServer.app/Contents/Info.plist +38 -0
  1436. data/test/performance/tools/mac/CmdTlmServer.app/Contents/MacOS/CmdTlmServer.rb +15 -0
  1437. data/test/performance/tools/mac/CmdTlmServer.app/Contents/MacOS/main.sh +6 -0
  1438. data/test/performance/tools/mac/CmdTlmServer.app/Contents/Resources/appIcon.icns +0 -0
  1439. data/test/performance/tools/mac/DataViewer.app/Contents/Info.plist +38 -0
  1440. data/test/performance/tools/mac/DataViewer.app/Contents/MacOS/DataViewer.rb +15 -0
  1441. data/test/performance/tools/mac/DataViewer.app/Contents/MacOS/main.sh +6 -0
  1442. data/test/performance/tools/mac/DataViewer.app/Contents/Resources/appIcon.icns +0 -0
  1443. data/test/performance/tools/mac/HandbookCreator.app/Contents/Info.plist +38 -0
  1444. data/test/performance/tools/mac/HandbookCreator.app/Contents/MacOS/HandbookCreator.rb +15 -0
  1445. data/test/performance/tools/mac/HandbookCreator.app/Contents/MacOS/main.sh +6 -0
  1446. data/test/performance/tools/mac/HandbookCreator.app/Contents/Resources/appIcon.icns +0 -0
  1447. data/test/performance/tools/mac/Launcher.app/Contents/Info.plist +38 -0
  1448. data/test/performance/tools/mac/Launcher.app/Contents/MacOS/Launcher.rb +15 -0
  1449. data/test/performance/tools/mac/Launcher.app/Contents/MacOS/main.sh +6 -0
  1450. data/test/performance/tools/mac/Launcher.app/Contents/Resources/appIcon.icns +0 -0
  1451. data/test/performance/tools/mac/LimitsMonitor.app/Contents/Info.plist +38 -0
  1452. data/test/performance/tools/mac/LimitsMonitor.app/Contents/MacOS/LimitsMonitor.rb +15 -0
  1453. data/test/performance/tools/mac/LimitsMonitor.app/Contents/MacOS/main.sh +6 -0
  1454. data/test/performance/tools/mac/LimitsMonitor.app/Contents/Resources/appIcon.icns +0 -0
  1455. data/test/performance/tools/mac/OpenGLBuilder.app/Contents/Info.plist +38 -0
  1456. data/test/performance/tools/mac/OpenGLBuilder.app/Contents/MacOS/OpenGLBuilder.rb +15 -0
  1457. data/test/performance/tools/mac/OpenGLBuilder.app/Contents/MacOS/main.sh +6 -0
  1458. data/test/performance/tools/mac/OpenGLBuilder.app/Contents/Resources/appIcon.icns +0 -0
  1459. data/test/performance/tools/mac/PacketViewer.app/Contents/Info.plist +38 -0
  1460. data/test/performance/tools/mac/PacketViewer.app/Contents/MacOS/PacketViewer.rb +15 -0
  1461. data/test/performance/tools/mac/PacketViewer.app/Contents/MacOS/main.sh +6 -0
  1462. data/test/performance/tools/mac/PacketViewer.app/Contents/Resources/appIcon.icns +0 -0
  1463. data/test/performance/tools/mac/Replay.app/Contents/Info.plist +38 -0
  1464. data/test/performance/tools/mac/Replay.app/Contents/MacOS/Replay.rb +15 -0
  1465. data/test/performance/tools/mac/Replay.app/Contents/MacOS/main.sh +6 -0
  1466. data/test/performance/tools/mac/Replay.app/Contents/Resources/appIcon.icns +0 -0
  1467. data/test/performance/tools/mac/ScriptRunner.app/Contents/Info.plist +38 -0
  1468. data/test/performance/tools/mac/ScriptRunner.app/Contents/MacOS/ScriptRunner.rb +15 -0
  1469. data/test/performance/tools/mac/ScriptRunner.app/Contents/MacOS/main.sh +6 -0
  1470. data/test/performance/tools/mac/ScriptRunner.app/Contents/Resources/appIcon.icns +0 -0
  1471. data/test/performance/tools/mac/TableManager.app/Contents/Info.plist +38 -0
  1472. data/test/performance/tools/mac/TableManager.app/Contents/MacOS/TableManager.rb +15 -0
  1473. data/test/performance/tools/mac/TableManager.app/Contents/MacOS/main.sh +6 -0
  1474. data/test/performance/tools/mac/TableManager.app/Contents/Resources/appIcon.icns +0 -0
  1475. data/test/performance/tools/mac/TestRunner.app/Contents/Info.plist +38 -0
  1476. data/test/performance/tools/mac/TestRunner.app/Contents/MacOS/TestRunner.rb +15 -0
  1477. data/test/performance/tools/mac/TestRunner.app/Contents/MacOS/main.sh +6 -0
  1478. data/test/performance/tools/mac/TestRunner.app/Contents/Resources/appIcon.icns +0 -0
  1479. data/test/performance/tools/mac/TlmExtractor.app/Contents/Info.plist +38 -0
  1480. data/test/performance/tools/mac/TlmExtractor.app/Contents/MacOS/TlmExtractor.rb +15 -0
  1481. data/test/performance/tools/mac/TlmExtractor.app/Contents/MacOS/main.sh +6 -0
  1482. data/test/performance/tools/mac/TlmExtractor.app/Contents/Resources/appIcon.icns +0 -0
  1483. data/test/performance/tools/mac/TlmGrapher.app/Contents/Info.plist +38 -0
  1484. data/test/performance/tools/mac/TlmGrapher.app/Contents/MacOS/TlmGrapher.rb +15 -0
  1485. data/test/performance/tools/mac/TlmGrapher.app/Contents/MacOS/main.sh +6 -0
  1486. data/test/performance/tools/mac/TlmGrapher.app/Contents/Resources/appIcon.icns +0 -0
  1487. data/test/performance/tools/mac/TlmViewer.app/Contents/Info.plist +38 -0
  1488. data/test/performance/tools/mac/TlmViewer.app/Contents/MacOS/TlmViewer.rb +15 -0
  1489. data/test/performance/tools/mac/TlmViewer.app/Contents/MacOS/main.sh +6 -0
  1490. data/test/performance/tools/mac/TlmViewer.app/Contents/Resources/appIcon.icns +0 -0
  1491. metadata +1964 -0
@@ -0,0 +1,13 @@
1
+ require 'mkmf'
2
+
3
+ unless $CFLAGS.gsub!(/ -O[\dsz]?/, ' -O3')
4
+ $CFLAGS << ' -O3'
5
+ end
6
+ if CONFIG['CC'] =~ /gcc/
7
+ $CFLAGS << ' -g -Wall'
8
+ if $DEBUG && !$CFLAGS.gsub!(/ -O[\dsz]?/, ' -O0 -ggdb')
9
+ $CFLAGS << ' -O0 -ggdb'
10
+ end
11
+ end
12
+
13
+ create_makefile 'cosmos/ext/platform'
@@ -0,0 +1,101 @@
1
+ /*
2
+ # Copyright 2014 Ball Aerospace & Technologies Corp.
3
+ # All Rights Reserved.
4
+ #
5
+ # This program is free software; you can modify and/or redistribute it
6
+ # under the terms of the GNU General Public License
7
+ # as published by the Free Software Foundation; version 3 with
8
+ # attribution addendums as found in the LICENSE.txt
9
+ */
10
+
11
+ #include "ruby.h"
12
+ #include "stdio.h"
13
+
14
+ /* Cosmos module reference */
15
+ VALUE mCosmos = Qnil;
16
+
17
+ /* SegFault class reference */
18
+ VALUE cSegFault = Qnil;
19
+
20
+ #ifdef _WIN32
21
+ #include <windows.h>
22
+ #else
23
+ #include <signal.h>
24
+ #include <unistd.h>
25
+ #include <time.h>
26
+
27
+ static void catch_sigsegv(int sig_num) {
28
+ char *cosmos_log_dir = NULL;
29
+ time_t rawtime;
30
+ struct tm *timeinfo;
31
+ char filename[256];
32
+ FILE* file = NULL;
33
+
34
+ signal(SIGSEGV, SIG_DFL);
35
+ signal(SIGILL, SIG_DFL);
36
+
37
+ cosmos_log_dir = getenv("COSMOS_LOGS_DIR");
38
+ if (cosmos_log_dir == NULL) {
39
+ cosmos_log_dir = (char*) ".";
40
+ }
41
+ time(&rawtime);
42
+ timeinfo = localtime(&rawtime);
43
+ sprintf(filename, "%s/%04u_%02u_%02u_%02u_%02u_%02u_segfault.txt",
44
+ cosmos_log_dir,
45
+ 1900 + timeinfo->tm_year,
46
+ 1 + timeinfo->tm_mon,
47
+ timeinfo->tm_mday,
48
+ timeinfo->tm_hour,
49
+ timeinfo->tm_min,
50
+ timeinfo->tm_sec);
51
+ file = freopen(filename, "a", stderr);
52
+ /* Using file removes a warning */
53
+ if (file) {
54
+ rb_bug("COSMOS caught segfault");
55
+ } else {
56
+ rb_bug("COSMOS caught segfault");
57
+ }
58
+ }
59
+ #endif
60
+
61
+ static VALUE segfault(VALUE self) {
62
+ char *a = 0;
63
+ *a = 50;
64
+ return Qnil;
65
+ }
66
+
67
+ /*
68
+ * Initialize methods for Platform specific C code
69
+ */
70
+ void Init_platform (void) {
71
+ #ifdef _WIN32
72
+ volatile VALUE ruby_version = rb_const_get(rb_cObject, rb_intern("RUBY_VERSION"));
73
+ char* rversion = RSTRING_PTR(ruby_version);
74
+
75
+ #if __x86_64__
76
+ if ((rversion[0] == '2') && (rversion[2] == '0')) {
77
+ LoadLibraryA("exchndl20-x64.dll");
78
+ } else if ((rversion[0] == '2') && (rversion[2] == '1')) {
79
+ LoadLibraryA("exchndl21-x64.dll");
80
+ } else if ((rversion[0] == '2') && (rversion[2] == '2')) {
81
+ LoadLibraryA("exchndl22-x64.dll");
82
+ }
83
+ #else
84
+ if ((rversion[0] == '2') && (rversion[2] == '0')) {
85
+ LoadLibraryA("exchndl20.dll");
86
+ } else if ((rversion[0] == '2') && (rversion[2] == '1')) {
87
+ LoadLibraryA("exchndl21.dll");
88
+ } else if ((rversion[0] == '2') && (rversion[2] == '2')) {
89
+ LoadLibraryA("exchndl22.dll");
90
+ }
91
+ #endif
92
+
93
+ #else
94
+ signal(SIGSEGV, catch_sigsegv);
95
+ signal(SIGILL, catch_sigsegv);
96
+ #endif
97
+
98
+ mCosmos = rb_define_module("Cosmos");
99
+ cSegFault = rb_define_class_under(mCosmos, "SegFault", rb_cObject);
100
+ rb_define_singleton_method(cSegFault, "segfault", segfault, 0);
101
+ }
@@ -0,0 +1,13 @@
1
+ require 'mkmf'
2
+
3
+ unless $CFLAGS.gsub!(/ -O[\dsz]?/, ' -O3')
4
+ $CFLAGS << ' -O3'
5
+ end
6
+ if CONFIG['CC'] =~ /gcc/
7
+ $CFLAGS << ' -Wall'
8
+ if $DEBUG && !$CFLAGS.gsub!(/ -O[\dsz]?/, ' -O0 -ggdb')
9
+ $CFLAGS << ' -O0 -ggdb'
10
+ end
11
+ end
12
+
13
+ create_makefile 'cosmos/ext/polynomial_conversion'
@@ -0,0 +1,73 @@
1
+ /*
2
+ # Copyright 2014 Ball Aerospace & Technologies Corp.
3
+ # All Rights Reserved.
4
+ #
5
+ # This program is free software; you can modify and/or redistribute it
6
+ # under the terms of the GNU General Public License
7
+ # as published by the Free Software Foundation; version 3 with
8
+ # attribution addendums as found in the LICENSE.txt
9
+ */
10
+
11
+ #include "ruby.h"
12
+ #include "stdio.h"
13
+ #include "math.h"
14
+
15
+ #ifndef RFLOAT_VALUE
16
+ #define RFLOAT_VALUE(v) (RFLOAT(v)->value)
17
+ #endif
18
+
19
+ VALUE mCosmos;
20
+ VALUE cConversion;
21
+ VALUE cPolynomialConversion;
22
+
23
+ static ID id_ivar_coeffs = 0;
24
+ static ID id_method_to_f = 0;
25
+
26
+ /*
27
+ * Calling this method performs a polynomial conversion on the given value.
28
+ *
29
+ * conversion.call(1, packet) #=> 2.5
30
+ */
31
+ static VALUE polynomial_conversion_call(VALUE self, VALUE value, VALUE myself, VALUE buffer)
32
+ {
33
+ volatile VALUE coeffs = Qnil;
34
+ long coeffs_length = 0;
35
+ int index = 0;
36
+ double double_value = 0.0;
37
+ double coeff = 0.0;
38
+ double converted = 0.0;
39
+ double raised_to_power = 1.0;
40
+
41
+ coeffs = rb_ivar_get(self, id_ivar_coeffs);
42
+ coeffs_length = RARRAY_LEN(coeffs);
43
+ double_value = RFLOAT_VALUE(rb_funcall(value, id_method_to_f, 0));
44
+
45
+ /* Handle C0 */
46
+ coeff = RFLOAT_VALUE(rb_ary_entry(coeffs, 0));
47
+ converted += coeff;
48
+
49
+ /* Handle Coefficients raised to a power */
50
+ for (index = 1; index < coeffs_length; index++)
51
+ {
52
+ raised_to_power *= double_value;
53
+ coeff = RFLOAT_VALUE(rb_ary_entry(coeffs, index));
54
+ converted += (coeff * raised_to_power);
55
+ }
56
+
57
+ return rb_float_new(converted);
58
+ }
59
+
60
+ /*
61
+ * Initialize methods for PolynomialConversion
62
+ */
63
+ void Init_polynomial_conversion (void)
64
+ {
65
+ id_ivar_coeffs = rb_intern("@coeffs");
66
+ id_method_to_f = rb_intern("to_f");
67
+
68
+ mCosmos = rb_define_module("Cosmos");
69
+ rb_require("cosmos/conversions/conversion");
70
+ cConversion = rb_const_get(mCosmos, rb_intern("Conversion"));
71
+ cPolynomialConversion = rb_define_class_under(mCosmos, "PolynomialConversion", cConversion);
72
+ rb_define_method(cPolynomialConversion, "call", polynomial_conversion_call, 3);
73
+ }
@@ -0,0 +1,13 @@
1
+ require 'mkmf'
2
+
3
+ unless $CFLAGS.gsub!(/ -O[\dsz]?/, ' -O3')
4
+ $CFLAGS << ' -O3'
5
+ end
6
+ if CONFIG['CC'] =~ /gcc/
7
+ $CFLAGS << ' -Wall'
8
+ if $DEBUG && !$CFLAGS.gsub!(/ -O[\dsz]?/, ' -O0 -ggdb')
9
+ $CFLAGS << ' -O0 -ggdb'
10
+ end
11
+ end
12
+
13
+ create_makefile 'cosmos/ext/string'
@@ -0,0 +1,49 @@
1
+ /*
2
+ # Copyright 2014 Ball Aerospace & Technologies Corp.
3
+ # All Rights Reserved.
4
+ #
5
+ # This program is free software; you can modify and/or redistribute it
6
+ # under the terms of the GNU General Public License
7
+ # as published by the Free Software Foundation; version 3 with
8
+ # attribution addendums as found in the LICENSE.txt
9
+ */
10
+
11
+ #include "ruby.h"
12
+ #include "stdio.h"
13
+
14
+ /*
15
+ * Removes quotes from the given string if present.
16
+ *
17
+ * "'quoted string'".remove_quotes #=> "quoted string"
18
+ */
19
+ static VALUE string_remove_quotes(VALUE self)
20
+ {
21
+ long length = RSTRING_LEN(self);
22
+ char* ptr = RSTRING_PTR(self);
23
+ char first_char = 0;
24
+ char last_char = 0;
25
+
26
+ if (length < 2) {
27
+ return self;
28
+ }
29
+
30
+ first_char = ptr[0];
31
+ if ((first_char != 34) && (first_char != 39)) {
32
+ return self;
33
+ }
34
+
35
+ last_char = ptr[length - 1];
36
+ if (last_char != first_char) {
37
+ return self;
38
+ }
39
+
40
+ return rb_str_new(ptr + 1, length - 2);
41
+ }
42
+
43
+ /*
44
+ * Initialize methods for String Core Ext
45
+ */
46
+ void Init_string (void)
47
+ {
48
+ rb_define_method(rb_cString, "remove_quotes", string_remove_quotes, 0);
49
+ }
@@ -0,0 +1,1433 @@
1
+ /*
2
+ # Copyright 2014 Ball Aerospace & Technologies Corp.
3
+ # All Rights Reserved.
4
+ #
5
+ # This program is free software; you can modify and/or redistribute it
6
+ # under the terms of the GNU Lesser General Public License
7
+ # as published by the Free Software Foundation; version 3 with
8
+ # attribution addendums as found in the LICENSE.txt
9
+ */
10
+
11
+ #include "ruby.h"
12
+ #include "stdio.h"
13
+
14
+ #define TO_BIGNUM(x) (FIXNUM_P(x) ? rb_int2big(FIX2LONG(x)) : x)
15
+ #define BYTE_ALIGNED(x) (((x) % 8) == 0)
16
+
17
+ static const int endianness_check = 1;
18
+ static VALUE HOST_ENDIANNESS = Qnil;
19
+ static VALUE ZERO_STRING = Qnil;
20
+ static VALUE ASCII_8BIT_STRING = Qnil;
21
+
22
+ static VALUE MIN_INT8 = Qnil;
23
+ static VALUE MAX_INT8 = Qnil;
24
+ static VALUE MAX_UINT8 = Qnil;
25
+ static VALUE MIN_INT16 = Qnil;
26
+ static VALUE MAX_INT16 = Qnil;
27
+ static VALUE MAX_UINT16 = Qnil;
28
+ static VALUE MIN_INT32 = Qnil;
29
+ static VALUE MAX_INT32 = Qnil;
30
+ static VALUE MAX_UINT32 = Qnil;
31
+ static VALUE MIN_INT64 = Qnil;
32
+ static VALUE MAX_INT64 = Qnil;
33
+ static VALUE MAX_UINT64 = Qnil;
34
+
35
+ static VALUE mCosmos = Qnil;
36
+ static VALUE cBinaryAccessor = Qnil;
37
+ static VALUE cStructure = Qnil;
38
+ static VALUE cStructureItem = Qnil;
39
+
40
+ static ID id_method_to_s = 0;
41
+ static ID id_method_raise_buffer_error = 0;
42
+ static ID id_method_read_array = 0;
43
+ static ID id_method_force_encoding = 0;
44
+ static ID id_method_freeze = 0;
45
+ static ID id_method_slice = 0;
46
+ static ID id_method_reverse = 0;
47
+ static ID id_method_Integer = 0;
48
+ static ID id_method_Float = 0;
49
+
50
+ static ID id_ivar_buffer = 0;
51
+ static ID id_ivar_bit_offset = 0;
52
+ static ID id_ivar_bit_size = 0;
53
+ static ID id_ivar_array_size = 0;
54
+ static ID id_ivar_endianness = 0;
55
+ static ID id_ivar_data_type = 0;
56
+ static ID id_ivar_default_endianness = 0;
57
+ static ID id_ivar_item_class = 0;
58
+ static ID id_ivar_items = 0;
59
+ static ID id_ivar_sorted_items = 0;
60
+ static ID id_ivar_defined_length = 0;
61
+ static ID id_ivar_defined_length_bits = 0;
62
+ static ID id_ivar_pos_bit_size = 0;
63
+ static ID id_ivar_neg_bit_size = 0;
64
+ static ID id_ivar_fixed_size = 0;
65
+ static ID id_ivar_short_buffer_allowed = 0;
66
+ static ID id_ivar_mutex = 0;
67
+
68
+ static ID id_const_ASCII_8BIT_STRING = 0;
69
+ static ID id_const_ZERO_STRING = 0;
70
+
71
+ static VALUE symbol_LITTLE_ENDIAN = Qnil;
72
+ static VALUE symbol_BIG_ENDIAN = Qnil;
73
+ static VALUE symbol_INT = Qnil;
74
+ static VALUE symbol_UINT = Qnil;
75
+ static VALUE symbol_FLOAT = Qnil;
76
+ static VALUE symbol_STRING = Qnil;
77
+ static VALUE symbol_BLOCK = Qnil;
78
+ static VALUE symbol_DERIVED = Qnil;
79
+ static VALUE symbol_read = Qnil;
80
+ static VALUE symbol_write = Qnil;
81
+ static VALUE symbol_TRUNCATE = Qnil;
82
+ static VALUE symbol_SATURATE = Qnil;
83
+ static VALUE symbol_ERROR = Qnil;
84
+ static VALUE symbol_ERROR_ALLOW_HEX = Qnil;
85
+
86
+ /*
87
+ * Perform an left bit shift on a string
88
+ */
89
+ static void left_shift_byte_array (unsigned char* array, int array_length, int shift)
90
+ {
91
+ int current_index = 0;
92
+ int previous_index = 0;
93
+ unsigned char saved_bits = 0;
94
+ unsigned char saved_bits_mask = (0xFF << (8 - shift));
95
+ unsigned char sign_extension_remove_mask = ~(0xFF << shift);
96
+
97
+ for (current_index = 0; current_index < array_length; current_index++)
98
+ {
99
+ /* Save bits that will be lost */
100
+ saved_bits = ((array[current_index] & saved_bits_mask) >> (8 - shift)) & sign_extension_remove_mask;
101
+
102
+ /* Perform shift on current byte */
103
+ array[current_index] <<= shift;
104
+
105
+ /* Add Saved bits to end of previous byte */
106
+ if (current_index > 0)
107
+ {
108
+ array[previous_index] |= saved_bits;
109
+ }
110
+
111
+ /* Update previous index */
112
+ previous_index = current_index;
113
+ }
114
+ }
115
+
116
+ /*
117
+ * Perform an unsigned right bit shift on a string
118
+ */
119
+ static void unsigned_right_shift_byte_array (unsigned char* array, int array_length, int shift)
120
+ {
121
+ int current_index = 0;
122
+ int previous_index = 0;
123
+ unsigned char saved_bits = 0;
124
+ unsigned char saved_bits_mask = ~(0xFF << shift);
125
+ unsigned char sign_extension_remove_mask = ~(0xFF << (8 - shift));
126
+
127
+ for (current_index = array_length - 1; current_index >= 0; current_index--)
128
+ {
129
+ /* Save bits that will be lost */
130
+ saved_bits = (array[current_index] & saved_bits_mask) << (8 - shift);
131
+
132
+ /* Perform shift on current byte */
133
+ array[current_index] = (array[current_index] >> shift) & sign_extension_remove_mask;
134
+
135
+ /* Add Saved bits to beginning of previous byte */
136
+ if (current_index != (array_length - 1))
137
+ {
138
+ array[previous_index] |= saved_bits;
139
+ }
140
+
141
+ /* Update previous index */
142
+ previous_index = current_index;
143
+ }
144
+ }
145
+
146
+ /*
147
+ * Perform an signed right bit shift on a string
148
+ */
149
+ static void signed_right_shift_byte_array (unsigned char* array, int array_length, int shift)
150
+ {
151
+ unsigned char start_bits_mask = (0xFF << (8 - shift));
152
+ int is_signed = (0x80 & array[0]);
153
+
154
+ unsigned_right_shift_byte_array(array, array_length, shift);
155
+
156
+ if (is_signed)
157
+ {
158
+ array[0] |= start_bits_mask;
159
+ }
160
+ }
161
+
162
+ /*
163
+ * Perform an unsigned bit shift on a string
164
+ */
165
+ static void unsigned_shift_byte_array (unsigned char* array, int array_length, int shift)
166
+ {
167
+ if (shift < 0)
168
+ {
169
+ left_shift_byte_array(array, array_length, -shift);
170
+ }
171
+ else if (shift > 0)
172
+ {
173
+ unsigned_right_shift_byte_array(array, array_length, shift);
174
+ }
175
+ }
176
+
177
+ /*
178
+ * Reverse the byte order in a string.
179
+ */
180
+ static void reverse_bytes (unsigned char* array, int array_length)
181
+ {
182
+ int first_index = 0;
183
+ int second_index = 0;
184
+ unsigned char temp_byte = 0;
185
+
186
+ for (first_index = 0; first_index < (array_length / 2); first_index++)
187
+ {
188
+ second_index = array_length - 1 - first_index;
189
+ temp_byte = array[first_index];
190
+ array[first_index] = array[second_index];
191
+ array[second_index] = temp_byte;
192
+ }
193
+ }
194
+
195
+ static void read_aligned_16(int lower_bound, int upper_bound, VALUE endianness, unsigned char *buffer, unsigned char *read_value) {
196
+ if (endianness == HOST_ENDIANNESS)
197
+ {
198
+ read_value[1] = buffer[upper_bound];
199
+ read_value[0] = buffer[lower_bound];
200
+ }
201
+ else
202
+ {
203
+ read_value[0] = buffer[upper_bound];
204
+ read_value[1] = buffer[lower_bound];
205
+ }
206
+ }
207
+
208
+ static void read_aligned_32(int lower_bound, int upper_bound, VALUE endianness, unsigned char *buffer, unsigned char *read_value) {
209
+ if (endianness == HOST_ENDIANNESS)
210
+ {
211
+ read_value[3] = buffer[upper_bound];
212
+ read_value[2] = buffer[upper_bound - 1];
213
+ read_value[1] = buffer[lower_bound + 1];
214
+ read_value[0] = buffer[lower_bound];
215
+ }
216
+ else
217
+ {
218
+ read_value[0] = buffer[upper_bound];
219
+ read_value[1] = buffer[upper_bound - 1];
220
+ read_value[2] = buffer[lower_bound + 1];
221
+ read_value[3] = buffer[lower_bound];
222
+ }
223
+ }
224
+
225
+ static void read_aligned_64(int lower_bound, int upper_bound, VALUE endianness, unsigned char *buffer, unsigned char *read_value) {
226
+ if (endianness == HOST_ENDIANNESS)
227
+ {
228
+ read_value[7] = buffer[upper_bound];
229
+ read_value[6] = buffer[upper_bound - 1];
230
+ read_value[5] = buffer[upper_bound - 2];
231
+ read_value[4] = buffer[upper_bound - 3];
232
+ read_value[3] = buffer[lower_bound + 3];
233
+ read_value[2] = buffer[lower_bound + 2];
234
+ read_value[1] = buffer[lower_bound + 1];
235
+ read_value[0] = buffer[lower_bound];
236
+ }
237
+ else
238
+ {
239
+ read_value[0] = buffer[upper_bound];
240
+ read_value[1] = buffer[upper_bound - 1];
241
+ read_value[2] = buffer[upper_bound - 2];
242
+ read_value[3] = buffer[upper_bound - 3];
243
+ read_value[4] = buffer[lower_bound + 3];
244
+ read_value[5] = buffer[lower_bound + 2];
245
+ read_value[6] = buffer[lower_bound + 1];
246
+ read_value[7] = buffer[lower_bound];
247
+ }
248
+ }
249
+
250
+ static void read_bitfield(int lower_bound, int upper_bound, int bit_offset, int bit_size, int given_bit_offset, int given_bit_size, VALUE endianness, unsigned char* buffer, int buffer_length, unsigned char* read_value) {
251
+ /* Local variables */
252
+ int num_bytes = 0;
253
+ int total_bits = 0;
254
+ int start_bits = 0;
255
+ int end_bits = 0;
256
+ int temp_upper = 0;
257
+ unsigned char end_mask = 0;
258
+
259
+ /* Copy Data For Bitfield into read_value */
260
+ if (endianness == symbol_LITTLE_ENDIAN)
261
+ {
262
+ /* Bitoffset always refers to the most significant bit of a bitfield */
263
+ num_bytes = (((bit_offset % 8) + bit_size - 1) / 8) + 1;
264
+ upper_bound = bit_offset / 8;
265
+ lower_bound = upper_bound - num_bytes + 1;
266
+
267
+ if (lower_bound < 0) {
268
+ rb_raise(rb_eArgError, "LITTLE_ENDIAN bitfield with bit_offset %d and bit_size %d is invalid", given_bit_offset, given_bit_size);
269
+ }
270
+
271
+ memcpy(read_value, &buffer[lower_bound], num_bytes);
272
+ reverse_bytes(read_value, num_bytes);
273
+ }
274
+ else
275
+ {
276
+ num_bytes = upper_bound - lower_bound + 1;
277
+ memcpy(read_value, &buffer[lower_bound], num_bytes);
278
+ }
279
+
280
+ /* Determine temp upper bound */
281
+ temp_upper = upper_bound - lower_bound;
282
+
283
+ /* Handle Bitfield */
284
+ total_bits = (temp_upper + 1) * 8;
285
+ start_bits = bit_offset % 8;
286
+ end_bits = total_bits - start_bits - bit_size;
287
+ end_mask = 0xFF << end_bits;
288
+
289
+ /* Mask off unwanted bits at end */
290
+ read_value[temp_upper] &= end_mask;
291
+
292
+ /* Shift off unwanted bits at beginning */
293
+ unsigned_shift_byte_array(read_value, num_bytes, -start_bits);
294
+ }
295
+
296
+ static void write_bitfield(int lower_bound, int upper_bound, int bit_offset, int bit_size, int given_bit_offset, int given_bit_size, VALUE endianness, unsigned char* buffer, int buffer_length, unsigned char* write_value) {
297
+ /* Local variables */
298
+ int num_bytes = 0;
299
+ int total_bits = 0;
300
+ int start_bits = 0;
301
+ int end_bits = 0;
302
+ int temp_upper = 0;
303
+ unsigned char start_mask = 0;
304
+ unsigned char end_mask = 0;
305
+
306
+ if (endianness == symbol_LITTLE_ENDIAN)
307
+ {
308
+ /* Bitoffset always refers to the most significant bit of a bitfield */
309
+ num_bytes = (((bit_offset % 8) + bit_size - 1) / 8) + 1;
310
+ upper_bound = bit_offset / 8;
311
+ lower_bound = upper_bound - num_bytes + 1;
312
+
313
+ if (lower_bound < 0) {
314
+ rb_raise(rb_eArgError, "LITTLE_ENDIAN bitfield with bit_offset %d and bit_size %d is invalid", given_bit_offset, given_bit_size);
315
+ }
316
+ }
317
+ else
318
+ {
319
+ num_bytes = upper_bound - lower_bound + 1;
320
+ }
321
+
322
+ /* Determine temp upper bound */
323
+ temp_upper = upper_bound - lower_bound;
324
+
325
+ /* Handle Bitfield */
326
+ total_bits = (temp_upper + 1) * 8;
327
+ start_bits = bit_offset % 8;
328
+ start_mask = 0xFF << (8 - start_bits);
329
+ end_bits = total_bits - start_bits - bit_size;
330
+ end_mask = 0xFF >> (8 - end_bits);
331
+
332
+ /* Shift to the right position */
333
+ unsigned_shift_byte_array(write_value, num_bytes, start_bits);
334
+
335
+ if (endianness == symbol_LITTLE_ENDIAN)
336
+ {
337
+ /* Mask in wanted bits at beginning */
338
+ write_value[0] |= buffer[upper_bound] & start_mask;
339
+
340
+ /* Mask in wanted bits at the end */
341
+ write_value[temp_upper] |= buffer[lower_bound] & end_mask;
342
+
343
+ reverse_bytes(write_value, num_bytes);
344
+ }
345
+ else
346
+ {
347
+ /* Mask in wanted bits at beginning */
348
+ write_value[0] |= buffer[lower_bound] & start_mask;
349
+
350
+ /* Mask in wanted bits at the end */
351
+ write_value[temp_upper] |= buffer[upper_bound] & end_mask;
352
+ }
353
+
354
+ /* Write the bytes into the buffer */
355
+ memcpy(&buffer[lower_bound], write_value, num_bytes);
356
+ }
357
+
358
+ /* Check the bit size and bit offset for problems. Recalulate the bit offset
359
+ * and return back through the passed in pointer. */
360
+ static void check_bit_offset_and_size(VALUE self, VALUE type_param, VALUE bit_offset_param, VALUE bit_size_param, VALUE data_type_param, VALUE buffer_param, int *new_bit_offset)
361
+ {
362
+ int bit_offset = NUM2INT(bit_offset_param);
363
+ int bit_size = NUM2INT(bit_size_param);
364
+
365
+ if ((bit_size <= 0) && (data_type_param != symbol_STRING) && (data_type_param != symbol_BLOCK)) {
366
+ rb_raise(rb_eArgError, "bit_size %d must be positive for data types other than :STRING and :BLOCK", bit_size);
367
+ }
368
+
369
+ if ((bit_size <= 0) && (bit_offset < 0)) {
370
+ rb_raise(rb_eArgError, "negative or zero bit_sizes (%d) cannot be given with negative bit_offsets (%d)", bit_size, bit_offset);
371
+ }
372
+
373
+ if (bit_offset < 0) {
374
+ bit_offset = ((RSTRING_LEN(buffer_param)* 8) + bit_offset);
375
+ if (bit_offset < 0) {
376
+ rb_funcall(self, id_method_raise_buffer_error, 5, type_param, buffer_param, data_type_param, bit_offset_param, bit_size_param);
377
+ }
378
+ }
379
+
380
+ *new_bit_offset = bit_offset;
381
+ }
382
+
383
+ /* Returns true if the bit_size is 8, 16, 32, or 64 */
384
+ static int even_bit_size(int bit_size)
385
+ {
386
+ return ((bit_size == 8) || (bit_size == 16) || (bit_size == 32) || (bit_size == 64));
387
+ }
388
+
389
+ /* Calculate the bounds of the string to access the item based on the bit_offset and bit_size.
390
+ * Also determine if the buffer size is sufficient. */
391
+ static int check_bounds_and_buffer_size(int bit_offset, int bit_size, int buffer_length, VALUE endianness, VALUE data_type, int *lower_bound, int *upper_bound)
392
+ {
393
+ int result = 1; /* Assume ok */
394
+
395
+ /* Define bounds of string to access this item */
396
+ *lower_bound = bit_offset / 8;
397
+ *upper_bound = (bit_offset + bit_size - 1) / 8;
398
+
399
+ /* Sanity check buffer size */
400
+ if (*upper_bound >= buffer_length) {
401
+ /* If it's not the special case of little endian bit field then we fail and return 0 */
402
+ if (!( (endianness == symbol_LITTLE_ENDIAN) &&
403
+ ((data_type == symbol_INT) || (data_type == symbol_UINT)) &&
404
+ /* Not byte aligned with an even bit size */
405
+ (!( (BYTE_ALIGNED(bit_offset)) && (even_bit_size(bit_size)) )) &&
406
+ (*lower_bound < buffer_length)
407
+ )) {
408
+ result = 0;
409
+ }
410
+ }
411
+ return result;
412
+ }
413
+
414
+ /*
415
+ * Reads binary data of any data type from a buffer
416
+ *
417
+ * @param bit_offset [Integer] Bit offset to the start of the item. A
418
+ * negative number means to offset from the end of the buffer.
419
+ * @param bit_size [Integer] Size of the item in bits
420
+ * @param data_type [Symbol] {DATA_TYPES}
421
+ * @param buffer [String] Binary string buffer to read from
422
+ * @param endianness [Symbol] {ENDIANNESS}
423
+ * @return [Integer] value read from the buffer
424
+ */
425
+ static VALUE binary_accessor_read(VALUE self, VALUE param_bit_offset, VALUE param_bit_size, VALUE param_data_type, VALUE param_buffer, VALUE param_endianness)
426
+ {
427
+ /* Convert Parameters to C Data Types */
428
+ int bit_offset = FIX2INT(param_bit_offset);
429
+ int bit_size = FIX2INT(param_bit_size);
430
+
431
+ /* Local Variables */
432
+ int given_bit_offset = bit_offset;
433
+ int given_bit_size = bit_size;
434
+ signed char signed_char_value = 0;
435
+ unsigned char unsigned_char_value = 0;
436
+ signed short signed_short_value = 0;
437
+ unsigned short unsigned_short_value = 0;
438
+ signed int signed_int_value = 0;
439
+ signed long signed_long_value = 0;
440
+ unsigned int unsigned_int_value = 0;
441
+ signed long long signed_long_long_value = 0;
442
+ unsigned long long unsigned_long_long_value = 0;
443
+ unsigned char* unsigned_char_array = NULL;
444
+ int array_length = 0;
445
+ char* string = NULL;
446
+ int string_length = 0;
447
+ float float_value = 0.0;
448
+ double double_value = 0.0;
449
+ int shift_needed = 0;
450
+ int shift_count = 0;
451
+ int index = 0;
452
+ int num_bits = 0;
453
+ int num_bytes = 0;
454
+ int num_words = 0;
455
+ int upper_bound = 0;
456
+ int lower_bound = 0;
457
+ volatile VALUE temp_value = Qnil;
458
+ volatile VALUE return_value = Qnil;
459
+
460
+ unsigned char* buffer = NULL;
461
+ long buffer_length = 0;
462
+
463
+ Check_Type(param_buffer, T_STRING);
464
+ buffer = (unsigned char*) RSTRING_PTR(param_buffer);
465
+ buffer_length = RSTRING_LEN(param_buffer);
466
+
467
+ check_bit_offset_and_size(self, symbol_read, param_bit_offset, param_bit_size,
468
+ param_data_type, param_buffer, &bit_offset);
469
+
470
+ /* If passed a negative bit size with strings or blocks
471
+ * recalculate based on the buffer length */
472
+ if ((bit_size <= 0) && ((param_data_type == symbol_STRING) || (param_data_type == symbol_BLOCK))) {
473
+ bit_size = (((int)buffer_length * 8) - bit_offset + bit_size);
474
+ if (bit_size == 0) {
475
+ return rb_str_new2("");
476
+ } else if (bit_size < 0) {
477
+ rb_funcall(self, id_method_raise_buffer_error, 5, symbol_read, param_buffer, param_data_type, param_bit_offset, param_bit_size);
478
+ }
479
+ }
480
+
481
+ if (!check_bounds_and_buffer_size(bit_offset, bit_size, buffer_length, param_endianness, param_data_type, &lower_bound, &upper_bound))
482
+ {
483
+ rb_funcall(self, id_method_raise_buffer_error, 5, symbol_read, param_buffer, param_data_type, param_bit_offset, param_bit_size);
484
+ }
485
+
486
+ if ((param_data_type == symbol_STRING) || (param_data_type == symbol_BLOCK)) {
487
+ /*#######################################
488
+ *# Handle :STRING and :BLOCK data types
489
+ *#######################################*/
490
+
491
+ if (BYTE_ALIGNED(bit_offset)) {
492
+ string_length = upper_bound - lower_bound + 1;
493
+ string = malloc(string_length + 1);
494
+ memcpy(string, buffer + lower_bound, string_length);
495
+ string[string_length] = 0;
496
+ if (param_data_type == symbol_STRING) {
497
+ return_value = rb_str_new2(string);
498
+ } else /* param_data_type == symbol_BLOCK */ {
499
+ return_value = rb_str_new(string, string_length);
500
+ }
501
+ free(string);
502
+ } else {
503
+ rb_raise(rb_eArgError, "bit_offset %d is not byte aligned for data_type %s", given_bit_offset, RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
504
+ }
505
+
506
+ } else if (param_data_type == symbol_INT) {
507
+ /*###################################
508
+ *# Handle :INT data type
509
+ *###################################*/
510
+
511
+ if ((BYTE_ALIGNED(bit_offset)) && (even_bit_size(bit_size)))
512
+ {
513
+ /*###########################################################
514
+ *# Handle byte-aligned 8, 16, 32, and 64 bit :INT
515
+ *###########################################################*/
516
+
517
+ switch (bit_size) {
518
+ case 8:
519
+ signed_char_value = *((signed char*) &buffer[lower_bound]);
520
+ return_value = INT2FIX(signed_char_value);
521
+ break;
522
+ case 16:
523
+ read_aligned_16(lower_bound, upper_bound, param_endianness, buffer, (unsigned char*) &signed_short_value);
524
+ return_value = INT2FIX(signed_short_value);
525
+ break;
526
+ case 32:
527
+ read_aligned_32(lower_bound, upper_bound, param_endianness, buffer, (unsigned char*) &signed_int_value);
528
+ return_value = INT2NUM(signed_int_value);
529
+ break;
530
+ case 64:
531
+ read_aligned_64(lower_bound, upper_bound, param_endianness, buffer, (unsigned char*) &signed_long_long_value);
532
+ return_value = LL2NUM(signed_long_long_value);
533
+ break;
534
+ }
535
+ } else {
536
+ string_length = ((bit_size - 1)/ 8) + 1;
537
+ array_length = string_length + 4; /* Required number of bytes plus slack */
538
+ unsigned_char_array = (unsigned char*) malloc(array_length);
539
+ read_bitfield(lower_bound, upper_bound, bit_offset, bit_size, given_bit_offset, given_bit_size, param_endianness, buffer, (int)buffer_length, unsigned_char_array);
540
+
541
+ num_words = ((string_length - 1) / 4) + 1;
542
+ num_bytes = num_words * 4;
543
+ num_bits = num_bytes * 8;
544
+ shift_needed = num_bits - bit_size;
545
+ shift_count = shift_needed / 8;
546
+ shift_needed = shift_needed % 8;
547
+
548
+ if (bit_size > 1) {
549
+ for (index = 0; index < shift_count; index++) {
550
+ signed_right_shift_byte_array(unsigned_char_array, num_bytes, 8);
551
+ }
552
+
553
+ if (shift_needed > 0) {
554
+ signed_right_shift_byte_array(unsigned_char_array, num_bytes, shift_needed);
555
+ }
556
+ } else {
557
+ for (index = 0; index < shift_count; index++) {
558
+ unsigned_right_shift_byte_array(unsigned_char_array, num_bytes, 8);
559
+ }
560
+
561
+ if (shift_needed > 0) {
562
+ unsigned_right_shift_byte_array(unsigned_char_array, num_bytes, shift_needed);
563
+ }
564
+ }
565
+
566
+ if (HOST_ENDIANNESS == symbol_LITTLE_ENDIAN) {
567
+ for (index = 0; index < num_bytes; index += 4) {
568
+ reverse_bytes(&(unsigned_char_array[index]), 4);
569
+ }
570
+ }
571
+
572
+ if (bit_size <= 31) {
573
+ return_value = INT2FIX(*((int*) unsigned_char_array));
574
+ } else if (bit_size == 32) {
575
+ return_value = INT2NUM(*((int*) unsigned_char_array));
576
+ } else {
577
+ return_value = rb_int2big(*((int*) unsigned_char_array));
578
+ temp_value = INT2FIX(32);
579
+ for (index = 4; index < num_bytes; index += 4) {
580
+ return_value = rb_big_lshift(return_value, temp_value);
581
+ if (FIXNUM_P(return_value)) {
582
+ signed_long_value = FIX2LONG(return_value);
583
+ return_value = rb_int2big(signed_long_value);
584
+ }
585
+ return_value = rb_big_plus(return_value, UINT2NUM(*((unsigned int*) &(unsigned_char_array[index]))));
586
+ if (FIXNUM_P(return_value)) {
587
+ signed_long_value = FIX2LONG(return_value);
588
+ return_value = rb_int2big(signed_long_value);
589
+ }
590
+ }
591
+ return_value = rb_big_norm(return_value);
592
+ }
593
+
594
+ free(unsigned_char_array);
595
+ }
596
+
597
+ } else if (param_data_type == symbol_UINT) {
598
+ /*###################################
599
+ *# Handle :UINT data type
600
+ *###################################*/
601
+
602
+ if ((BYTE_ALIGNED(bit_offset)) && (even_bit_size(bit_size)))
603
+ {
604
+ /*###########################################################
605
+ *# Handle byte-aligned 8, 16, 32, and 64 bit :UINT
606
+ *###########################################################*/
607
+
608
+ switch (bit_size) {
609
+ case 8:
610
+ unsigned_char_value = buffer[lower_bound];
611
+ return_value = INT2FIX(unsigned_char_value);
612
+ break;
613
+ case 16:
614
+ read_aligned_16(lower_bound, upper_bound, param_endianness, buffer, (unsigned char*) &unsigned_short_value);
615
+ return_value = INT2FIX(unsigned_short_value);
616
+ break;
617
+ case 32:
618
+ read_aligned_32(lower_bound, upper_bound, param_endianness, buffer, (unsigned char*) &unsigned_int_value);
619
+ return_value = UINT2NUM(unsigned_int_value);
620
+ break;
621
+ case 64:
622
+ read_aligned_64(lower_bound, upper_bound, param_endianness, buffer, (unsigned char*) &unsigned_long_long_value);
623
+ return_value = ULL2NUM(unsigned_long_long_value);
624
+ break;
625
+ }
626
+ } else {
627
+ string_length = ((bit_size - 1)/ 8) + 1;
628
+ array_length = string_length + 4; /* Required number of bytes plus slack */
629
+ unsigned_char_array = (unsigned char*) malloc(array_length);
630
+ read_bitfield(lower_bound, upper_bound, bit_offset, bit_size, given_bit_offset, given_bit_size, param_endianness, buffer, (int)buffer_length, unsigned_char_array);
631
+
632
+ num_words = ((string_length - 1) / 4) + 1;
633
+ num_bytes = num_words * 4;
634
+ num_bits = num_bytes * 8;
635
+ shift_needed = num_bits - bit_size;
636
+ shift_count = shift_needed / 8;
637
+ shift_needed = shift_needed % 8;
638
+
639
+ for (index = 0; index < shift_count; index++) {
640
+ unsigned_right_shift_byte_array(unsigned_char_array, num_bytes, 8);
641
+ }
642
+
643
+ if (shift_needed > 0) {
644
+ unsigned_right_shift_byte_array(unsigned_char_array, num_bytes, shift_needed);
645
+ }
646
+
647
+ if (HOST_ENDIANNESS == symbol_LITTLE_ENDIAN) {
648
+ for (index = 0; index < num_bytes; index += 4) {
649
+ reverse_bytes(&(unsigned_char_array[index]), 4);
650
+ }
651
+ }
652
+
653
+ if (bit_size <= 30) {
654
+ return_value = INT2FIX(*((int*) unsigned_char_array));
655
+ } else if (bit_size <= 32) {
656
+ return_value = UINT2NUM(*((unsigned int*) unsigned_char_array));
657
+ } else {
658
+ return_value = rb_uint2big(*((unsigned int*) unsigned_char_array));
659
+ temp_value = INT2FIX(32);
660
+ for (index = 4; index < num_bytes; index += 4) {
661
+ return_value = rb_big_lshift(return_value, temp_value);
662
+ if (FIXNUM_P(return_value)) {
663
+ signed_long_value = FIX2LONG(return_value);
664
+ return_value = rb_int2big(signed_long_value);
665
+ }
666
+ return_value = rb_big_plus(return_value, UINT2NUM(*((unsigned int*) &(unsigned_char_array[index]))));
667
+ if (FIXNUM_P(return_value)) {
668
+ signed_long_value = FIX2LONG(return_value);
669
+ return_value = rb_int2big(signed_long_value);
670
+ }
671
+ }
672
+ return_value = rb_big_norm(return_value);
673
+ }
674
+
675
+ free(unsigned_char_array);
676
+ }
677
+
678
+ } else if (param_data_type == symbol_FLOAT) {
679
+ /*##########################
680
+ *# Handle :FLOAT data type
681
+ *##########################*/
682
+
683
+ if (BYTE_ALIGNED(bit_offset)) {
684
+ switch (bit_size) {
685
+ case 32:
686
+ read_aligned_32(lower_bound, upper_bound, param_endianness, buffer, (unsigned char*) &float_value);
687
+ return_value = rb_float_new(float_value);
688
+ break;
689
+
690
+ case 64:
691
+ read_aligned_64(lower_bound, upper_bound, param_endianness, buffer, (unsigned char*) &double_value);
692
+ return_value = rb_float_new(double_value);
693
+ break;
694
+
695
+ default:
696
+ rb_raise(rb_eArgError, "bit_size is %d but must be 32 or 64 for data_type %s", given_bit_size, RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
697
+ break;
698
+ };
699
+ } else {
700
+ rb_raise(rb_eArgError, "bit_offset %d is not byte aligned for data_type %s", given_bit_offset, RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
701
+ }
702
+
703
+ } else {
704
+ /*############################
705
+ *# Handle Unknown data types
706
+ *############################*/
707
+
708
+ rb_raise(rb_eArgError, "data_type %s is not recognized", RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
709
+ }
710
+
711
+ return return_value;
712
+ }
713
+
714
+ static VALUE check_overflow(VALUE value, int bit_size, VALUE data_type, VALUE overflow)
715
+ {
716
+ volatile VALUE hex_max_value = Qnil;
717
+ volatile VALUE max_value = Qnil;
718
+ volatile VALUE min_value = INT2NUM(0); /* Default for UINT cases */
719
+
720
+ switch (bit_size) {
721
+ case 8:
722
+ hex_max_value = MAX_UINT8;
723
+ if (data_type == symbol_INT) {
724
+ min_value = MIN_INT8;
725
+ max_value = MAX_INT8;
726
+ } else {
727
+ max_value = MAX_UINT8;
728
+ }
729
+ break;
730
+ case 16:
731
+ hex_max_value = MAX_UINT16;
732
+ if (data_type == symbol_INT) {
733
+ min_value = MIN_INT16;
734
+ max_value = MAX_INT16;
735
+ } else {
736
+ max_value = MAX_UINT16;
737
+ }
738
+ break;
739
+ case 32:
740
+ hex_max_value = MAX_UINT32;
741
+ if (data_type == symbol_INT) {
742
+ min_value = MIN_INT32;
743
+ max_value = MAX_INT32;
744
+ } else {
745
+ max_value = MAX_UINT32;
746
+ }
747
+ break;
748
+ case 64:
749
+ hex_max_value = MAX_UINT64;
750
+ if (data_type == symbol_INT) {
751
+ min_value = MIN_INT64;
752
+ max_value = MAX_INT64;
753
+ } else {
754
+ max_value = MAX_UINT64;
755
+ }
756
+ break;
757
+ default: /* Bitfield */
758
+ if (data_type == symbol_INT) {
759
+ /* Note signed integers must allow up to the maximum unsigned value to support values given in hex */
760
+ if (bit_size > 1) {
761
+ max_value = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(bit_size - 1));
762
+ /* min_value = -(2 ** bit_size - 1) */
763
+ min_value = rb_big_minus(TO_BIGNUM(INT2NUM(0)), max_value);
764
+ /* max_value = (2 ** bit_size - 1) - 1 */
765
+ max_value = rb_big_minus(TO_BIGNUM(max_value), INT2NUM(1));
766
+ /* hex_max_value = (2 ** bit_size) - 1 */
767
+ hex_max_value = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(bit_size));
768
+ hex_max_value = rb_big_minus(TO_BIGNUM(hex_max_value), INT2NUM(1));
769
+ } else { /* 1-bit signed */
770
+ min_value = INT2NUM(-1);
771
+ max_value = INT2NUM(1);
772
+ hex_max_value = INT2NUM(1);
773
+ }
774
+ } else {
775
+ max_value = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(bit_size));
776
+ max_value = rb_big_minus(TO_BIGNUM(max_value), INT2NUM(1));
777
+ hex_max_value = max_value;
778
+ }
779
+ break;
780
+ }
781
+ /* Convert all to Bignum objects so we can do the math the same way */
782
+ value = TO_BIGNUM(value);
783
+ min_value = TO_BIGNUM(min_value);
784
+ max_value = TO_BIGNUM(max_value);
785
+ hex_max_value = TO_BIGNUM(hex_max_value);
786
+
787
+ if (overflow == symbol_TRUNCATE) {
788
+ /* Note this will always convert to unsigned equivalent for signed integers */
789
+ value = rb_big_modulo(value, TO_BIGNUM(rb_big_plus(hex_max_value, INT2NUM(1))));
790
+ } else {
791
+ if (rb_big_cmp(value, max_value) == INT2FIX(1)) {
792
+ if (overflow == symbol_SATURATE) {
793
+ value = max_value;
794
+ } else {
795
+ if ((overflow == symbol_ERROR) || (rb_big_cmp(value, hex_max_value) == INT2FIX(1))) {
796
+ rb_raise(rb_eArgError, "value of %s invalid for %d-bit %s",
797
+ RSTRING_PTR(rb_funcall(value, id_method_to_s, 0)),
798
+ bit_size,
799
+ RSTRING_PTR(rb_funcall(data_type, id_method_to_s, 0)));
800
+ }
801
+ }
802
+ } else if (rb_big_cmp(value, min_value) == INT2FIX(-1)) {
803
+ if (overflow == symbol_SATURATE) {
804
+ value = min_value;
805
+ } else {
806
+ rb_raise(rb_eArgError, "value of %s invalid for %d-bit %s",
807
+ RSTRING_PTR(rb_funcall(value, id_method_to_s, 0)),
808
+ bit_size,
809
+ RSTRING_PTR(rb_funcall(data_type, id_method_to_s, 0)));
810
+ }
811
+ }
812
+ }
813
+
814
+ return rb_big_norm(value);
815
+ }
816
+
817
+ /*
818
+ * Writes binary data of any data type to a buffer
819
+ *
820
+ * @param bit_offset [Integer] Bit offset to the start of the item. A
821
+ * negative number means to offset from the end of the buffer.
822
+ * @param bit_size [Integer] Size of the item in bits
823
+ * @param data_type [Symbol] {DATA_TYPES}
824
+ * @param buffer [String] Binary string buffer to read from
825
+ * @param endianness [Symbol] {ENDIANNESS}
826
+ * @return [Integer] value read from the buffer
827
+ */
828
+ static VALUE binary_accessor_write(VALUE self, VALUE value, VALUE param_bit_offset, VALUE param_bit_size, VALUE param_data_type, VALUE param_buffer, VALUE param_endianness, VALUE param_overflow)
829
+ {
830
+ /* Convert Parameters to C Data Types */
831
+ int bit_offset = NUM2INT(param_bit_offset);
832
+ int bit_size = NUM2INT(param_bit_size);
833
+ /* Local Variables */
834
+ int given_bit_offset = bit_offset;
835
+ int given_bit_size = bit_size;
836
+ int upper_bound = 0;
837
+ int lower_bound = 0;
838
+ int end_bytes = 0;
839
+ int old_upper_bound = 0;
840
+ int byte_size = 0;
841
+
842
+ unsigned long long c_value = 0;
843
+ float float_value = 0.0;
844
+ double double_value = 0.0;
845
+
846
+ unsigned char* buffer = NULL;
847
+ long buffer_length = 0;
848
+ long value_length = 0;
849
+ volatile VALUE temp_shift = Qnil;
850
+ volatile VALUE temp_mask = Qnil;
851
+ volatile VALUE temp_result = Qnil;
852
+
853
+ int string_length = 0;
854
+ unsigned char* unsigned_char_array = NULL;
855
+ int array_length = 0;
856
+ int shift_needed = 0;
857
+ int shift_count = 0;
858
+ int index = 0;
859
+ int num_bits = 0;
860
+ int num_bytes = 0;
861
+ int num_words = 0;
862
+
863
+ Check_Type(param_buffer, T_STRING);
864
+ buffer = (unsigned char*) RSTRING_PTR(param_buffer);
865
+ buffer_length = RSTRING_LEN(param_buffer);
866
+
867
+ check_bit_offset_and_size(self, symbol_write, param_bit_offset, param_bit_size,
868
+ param_data_type, param_buffer, &bit_offset);
869
+
870
+ /* If passed a negative bit size with strings or blocks
871
+ * recalculate based on the value length in bytes */
872
+ if ((bit_size <= 0) && ((param_data_type == symbol_STRING) || (param_data_type == symbol_BLOCK))) {
873
+ if (!RB_TYPE_P(value, T_STRING)) {
874
+ value = rb_funcall(value, id_method_to_s, 0);
875
+ }
876
+ bit_size = RSTRING_LEN(value) * 8;
877
+ }
878
+
879
+ if ((!check_bounds_and_buffer_size(bit_offset, bit_size, buffer_length, param_endianness, param_data_type, &lower_bound, &upper_bound)) && (given_bit_size > 0))
880
+ {
881
+ rb_funcall(self, id_method_raise_buffer_error, 5, symbol_write, param_buffer, param_data_type, param_bit_offset, param_bit_size);
882
+ }
883
+
884
+ /* Check overflow type */
885
+ if ((param_overflow != symbol_TRUNCATE) &&
886
+ (param_overflow != symbol_SATURATE) &&
887
+ (param_overflow != symbol_ERROR) &&
888
+ (param_overflow != symbol_ERROR_ALLOW_HEX)) {
889
+ rb_raise(rb_eArgError, "unknown overflow type %s", RSTRING_PTR(rb_funcall(param_overflow, id_method_to_s, 0)));
890
+ }
891
+
892
+ if ((param_data_type == symbol_STRING) || (param_data_type == symbol_BLOCK)) {
893
+ /*#######################################
894
+ *# Handle :STRING and :BLOCK data types
895
+ *#######################################*/
896
+ /* Force value to be a string */
897
+ if (!RB_TYPE_P(value, T_STRING)) {
898
+ value = rb_funcall(value, id_method_to_s, 0);
899
+ }
900
+
901
+ if (BYTE_ALIGNED(bit_offset)) {
902
+ value_length = RSTRING_LEN(value);
903
+
904
+ if (given_bit_size <= 0) {
905
+ end_bytes = -(given_bit_size / 8);
906
+ old_upper_bound = buffer_length - 1 - end_bytes;
907
+ /* Lower bound + end_bytes can never be more than 1 byte outside of the given buffer */
908
+ if ((lower_bound + end_bytes) > buffer_length)
909
+ {
910
+ rb_funcall(self, id_method_raise_buffer_error, 5, symbol_write, param_buffer, param_data_type, param_bit_offset, param_bit_size);
911
+ }
912
+
913
+ if (old_upper_bound < lower_bound) {
914
+ /* String was completely empty */
915
+ if (end_bytes > 0) {
916
+ /* Preserve bytes at end of buffer */
917
+ rb_str_concat(param_buffer, rb_str_times(ZERO_STRING, INT2FIX(value_length)));
918
+ buffer = (unsigned char*) RSTRING_PTR(param_buffer);
919
+ memmove((buffer + lower_bound + value_length), (buffer + lower_bound), end_bytes);
920
+ }
921
+ } else if (bit_size == 0) {
922
+ /* Remove entire string */
923
+ rb_str_update(param_buffer, lower_bound, old_upper_bound - lower_bound + 1, rb_str_new2(""));
924
+ } else if (upper_bound < old_upper_bound) {
925
+ /* Remove extra bytes from old string */
926
+ rb_str_update(param_buffer, upper_bound + 1, old_upper_bound - upper_bound, rb_str_new2(""));
927
+ } else if ((upper_bound > old_upper_bound) && (end_bytes > 0)) {
928
+ /* Preserve bytes at end of buffer */
929
+ rb_str_concat(param_buffer, rb_str_times(ZERO_STRING, INT2FIX(upper_bound - old_upper_bound)));
930
+ buffer = (unsigned char*) RSTRING_PTR(param_buffer);
931
+ memmove((buffer + upper_bound + 1), (buffer + old_upper_bound + 1), end_bytes);
932
+ }
933
+ } else {
934
+ byte_size = bit_size / 8;
935
+ if (value_length < byte_size) {
936
+ /* Pad the requested size with zeros.
937
+ * Tell Ruby we are going to be modifying the buffer with a memset */
938
+ rb_str_modify(param_buffer);
939
+ memset(RSTRING_PTR(param_buffer) + lower_bound + value_length, 0, byte_size - value_length);
940
+ } else if (value_length > byte_size) {
941
+ if (param_overflow == symbol_TRUNCATE) {
942
+ /* Resize the value to fit the field */
943
+ rb_str_update(value, byte_size, RSTRING_LEN(value) - byte_size, rb_str_new2(""));
944
+ } else {
945
+ rb_raise(rb_eArgError, "value of %d bytes does not fit into %d bytes for data_type %s", (int)value_length, byte_size, RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
946
+ }
947
+ }
948
+ }
949
+ if (bit_size != 0) {
950
+ rb_str_update(param_buffer, lower_bound, RSTRING_LEN(value), value);
951
+ }
952
+ } else {
953
+ rb_raise(rb_eArgError, "bit_offset %d is not byte aligned for data_type %s", given_bit_offset, RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
954
+ }
955
+
956
+ } else if ((param_data_type == symbol_INT) || (param_data_type == symbol_UINT)) {
957
+ /*###################################
958
+ *# Handle :INT data type
959
+ *###################################*/
960
+ value = rb_funcall(rb_mKernel, id_method_Integer, 1, value);
961
+
962
+ if ((BYTE_ALIGNED(bit_offset)) && (even_bit_size(bit_size)))
963
+ {
964
+ /*###########################################################
965
+ *# Handle byte-aligned 8, 16, 32, and 64 bit
966
+ *###########################################################*/
967
+
968
+ value = check_overflow(value, bit_size, param_data_type, param_overflow);
969
+ switch (bit_size) {
970
+ case 8:
971
+ c_value = NUM2CHR(value);
972
+ break;
973
+ case 16:
974
+ c_value = NUM2USHORT(value);
975
+ break;
976
+ case 32:
977
+ c_value = NUM2UINT(value);
978
+ break;
979
+ case 64:
980
+ c_value = NUM2ULL(value);
981
+ break;
982
+ }
983
+ /* If the passed endianess doesn't match the host we reverse the bytes.
984
+ * Then shift the result over so it's at the bottom of the long long value. */
985
+ if (param_endianness != HOST_ENDIANNESS) {
986
+ reverse_bytes((unsigned char *)&c_value, 8);
987
+ c_value = (c_value >> (64 - bit_size));
988
+ }
989
+ /* Tell Ruby we are going to be modifying the buffer with a memcpy */
990
+ rb_str_modify(param_buffer);
991
+ memcpy((RSTRING_PTR(param_buffer) + lower_bound), &c_value, bit_size / 8);
992
+
993
+ } else {
994
+ /*###########################################################
995
+ *# Handle bit fields
996
+ *###########################################################*/
997
+ value = check_overflow(value, bit_size, param_data_type, param_overflow);
998
+
999
+ string_length = ((bit_size - 1)/ 8) + 1;
1000
+ array_length = string_length + 4; /* Required number of bytes plus slack */
1001
+ unsigned_char_array = (unsigned char*) malloc(array_length);
1002
+
1003
+ num_words = ((string_length - 1) / 4) + 1;
1004
+ num_bytes = num_words * 4;
1005
+ num_bits = num_bytes * 8;
1006
+ shift_needed = num_bits - bit_size;
1007
+ shift_count = shift_needed / 8;
1008
+ shift_needed = shift_needed % 8;
1009
+
1010
+ /* Convert value into array of bytes */
1011
+ if (bit_size <= 30) {
1012
+ *((int *)unsigned_char_array) = FIX2INT(value);
1013
+ } else if (bit_size <= 32) {
1014
+ *((unsigned int *)unsigned_char_array) = NUM2UINT(value);
1015
+ } else {
1016
+ temp_mask = UINT2NUM(0xFFFFFFFF);
1017
+ temp_shift = INT2FIX(32);
1018
+ temp_result = rb_big_and(TO_BIGNUM(value), temp_mask);
1019
+ /* Work around bug where rb_big_and will return Qfalse if given a first parameter of 0 */
1020
+ if (temp_result == Qfalse) { temp_result = INT2FIX(0); }
1021
+ *((unsigned int *)&(unsigned_char_array[num_bytes - 4])) = NUM2UINT(temp_result);
1022
+ for (index = num_bytes - 8; index >= 0; index -= 4) {
1023
+ value = rb_big_rshift(TO_BIGNUM(value), temp_shift);
1024
+ temp_result = rb_big_and(TO_BIGNUM(value), temp_mask);
1025
+ /* Work around bug where rb_big_and will return Qfalse if given a first parameter of 0 */
1026
+ if (temp_result == Qfalse) { temp_result = INT2FIX(0); }
1027
+ *((unsigned int *)&(unsigned_char_array[index])) = NUM2UINT(temp_result);
1028
+ }
1029
+ }
1030
+
1031
+ if (HOST_ENDIANNESS == symbol_LITTLE_ENDIAN) {
1032
+ for (index = 0; index < num_bytes; index += 4) {
1033
+ reverse_bytes(&(unsigned_char_array[index]), 4);
1034
+ }
1035
+ }
1036
+
1037
+ for (index = 0; index < shift_count; index++) {
1038
+ left_shift_byte_array(unsigned_char_array, num_bytes, 8);
1039
+ }
1040
+
1041
+ if (shift_needed > 0) {
1042
+ left_shift_byte_array(unsigned_char_array, num_bytes, shift_needed);
1043
+ }
1044
+
1045
+ rb_str_modify(param_buffer);
1046
+ write_bitfield(lower_bound, upper_bound, bit_offset, bit_size, given_bit_offset, given_bit_size, param_endianness, (unsigned char*) RSTRING_PTR(param_buffer), (int)buffer_length, unsigned_char_array);
1047
+
1048
+ free(unsigned_char_array);
1049
+ }
1050
+
1051
+ } else if (param_data_type == symbol_FLOAT) {
1052
+ /*##########################
1053
+ *# Handle :FLOAT data type
1054
+ *##########################*/
1055
+ value = rb_funcall(rb_mKernel, id_method_Float, 1, value);
1056
+
1057
+ if (BYTE_ALIGNED(bit_offset)) {
1058
+ switch (bit_size) {
1059
+ case 32:
1060
+ float_value = (float)RFLOAT_VALUE(value);
1061
+ if (param_endianness != HOST_ENDIANNESS) {
1062
+ reverse_bytes((unsigned char *)&float_value, 4);
1063
+ }
1064
+ rb_str_modify(param_buffer);
1065
+ memcpy((RSTRING_PTR(param_buffer) + lower_bound), &float_value, 4);
1066
+ break;
1067
+
1068
+ case 64:
1069
+ double_value = RFLOAT_VALUE(value);
1070
+ if (param_endianness != HOST_ENDIANNESS) {
1071
+ reverse_bytes((unsigned char *)&double_value, 8);
1072
+ }
1073
+ rb_str_modify(param_buffer);
1074
+ memcpy((RSTRING_PTR(param_buffer) + lower_bound), &double_value, 8);
1075
+ break;
1076
+
1077
+ default:
1078
+ rb_raise(rb_eArgError, "bit_size is %d but must be 32 or 64 for data_type %s", given_bit_size, RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
1079
+ break;
1080
+ };
1081
+ } else {
1082
+ rb_raise(rb_eArgError, "bit_offset %d is not byte aligned for data_type %s", given_bit_offset, RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
1083
+ }
1084
+
1085
+ } else {
1086
+ /*############################
1087
+ *# Handle Unknown data types
1088
+ *############################*/
1089
+
1090
+ rb_raise(rb_eArgError, "data_type %s is not recognized", RSTRING_PTR(rb_funcall(param_data_type, id_method_to_s, 0)));
1091
+ }
1092
+
1093
+ return value;
1094
+ }
1095
+
1096
+ /*
1097
+ * Returns the actual length as an integer.
1098
+ *
1099
+ * get_int_length(self) #=> 324
1100
+ */
1101
+ static int get_int_length(VALUE self)
1102
+ {
1103
+ volatile VALUE buffer = rb_ivar_get(self, id_ivar_buffer);
1104
+ if (RTEST(buffer)) {
1105
+ return (int)RSTRING_LEN(buffer);
1106
+ } else {
1107
+ return 0;
1108
+ }
1109
+ }
1110
+
1111
+ /*
1112
+ * Returns the actual structure length.
1113
+ *
1114
+ * structure.length #=> 324
1115
+ */
1116
+ static VALUE structure_length(VALUE self) {
1117
+ return INT2FIX(get_int_length(self));
1118
+ }
1119
+
1120
+ static VALUE read_item_internal(VALUE self, VALUE item, VALUE buffer) {
1121
+ volatile VALUE bit_offset = Qnil;
1122
+ volatile VALUE bit_size = Qnil;
1123
+ volatile VALUE data_type = Qnil;
1124
+ volatile VALUE array_size = Qnil;
1125
+ volatile VALUE endianness = Qnil;
1126
+
1127
+ data_type = rb_ivar_get(item, id_ivar_data_type);
1128
+ if (data_type == symbol_DERIVED) {
1129
+ return Qnil;
1130
+ }
1131
+
1132
+ if (RTEST(buffer)) {
1133
+ bit_offset = rb_ivar_get(item, id_ivar_bit_offset);
1134
+ bit_size = rb_ivar_get(item, id_ivar_bit_size);
1135
+ array_size = rb_ivar_get(item, id_ivar_array_size);
1136
+ endianness = rb_ivar_get(item, id_ivar_endianness);
1137
+ if (RTEST(array_size)) {
1138
+ return rb_funcall(cBinaryAccessor, id_method_read_array, 6, bit_offset, bit_size, data_type, array_size, buffer, endianness);
1139
+ } else {
1140
+ return binary_accessor_read(cBinaryAccessor, bit_offset, bit_size, data_type, buffer, endianness);
1141
+ }
1142
+ } else {
1143
+ rb_raise(rb_eRuntimeError, "No buffer given to read_item");
1144
+ }
1145
+ }
1146
+
1147
+ /*
1148
+ * Read an item in the structure
1149
+ *
1150
+ * @param item [StructureItem] Instance of StructureItem or one of its subclasses
1151
+ * @param value_type [Symbol] Not used. Subclasses should overload this
1152
+ * parameter to check whether to perform conversions on the item.
1153
+ * @param buffer [String] The binary buffer to read the item from
1154
+ * @return Value based on the item definition. This could be a string, integer,
1155
+ * float, or array of values.
1156
+ */
1157
+ static VALUE read_item(int argc, VALUE* argv, VALUE self)
1158
+ {
1159
+ volatile VALUE item = Qnil;
1160
+ volatile VALUE buffer = Qnil;
1161
+
1162
+ switch (argc)
1163
+ {
1164
+ case 1:
1165
+ case 2:
1166
+ item = argv[0];
1167
+ buffer = rb_ivar_get(self, id_ivar_buffer);
1168
+ break;
1169
+ case 3:
1170
+ item = argv[0];
1171
+ buffer = argv[2];
1172
+ break;
1173
+ default:
1174
+ /* Invalid number of arguments given */
1175
+ rb_raise(rb_eArgError, "wrong number of arguments (%d for 1..3)", argc);
1176
+ break;
1177
+ };
1178
+
1179
+ return read_item_internal(self, item, buffer);
1180
+ }
1181
+
1182
+ /*
1183
+ * Comparison Operator based on bit_offset. This means that StructureItems
1184
+ * with different names or bit sizes are equal if they have the same bit
1185
+ * offset.
1186
+ */
1187
+ static VALUE structure_item_spaceship(VALUE self, VALUE other_item) {
1188
+ int bit_offset = FIX2INT(rb_ivar_get(self, id_ivar_bit_offset));
1189
+ int other_bit_offset = FIX2INT(rb_ivar_get(other_item, id_ivar_bit_offset));
1190
+ int bit_size = 0;
1191
+ int other_bit_size = 0;
1192
+
1193
+ /* Handle same bit offset case */
1194
+ if ((bit_offset == 0) && (other_bit_offset == 0)) {
1195
+ /* Both bit_offsets are 0 so sort by bit_size
1196
+ * This allows derived items with bit_size of 0 to be listed first
1197
+ * Compare based on bit size */
1198
+ bit_size = FIX2INT(rb_ivar_get(self, id_ivar_bit_size));
1199
+ other_bit_size = FIX2INT(rb_ivar_get(other_item, id_ivar_bit_size));
1200
+ if (bit_size == other_bit_size) {
1201
+ return INT2FIX(0);
1202
+ } if (bit_size < other_bit_size) {
1203
+ return INT2FIX(-1);
1204
+ } else {
1205
+ return INT2FIX(1);
1206
+ }
1207
+ }
1208
+
1209
+ /* Handle different bit offsets */
1210
+ if (((bit_offset >= 0) && (other_bit_offset >= 0)) || ((bit_offset < 0) && (other_bit_offset < 0))) {
1211
+ /* Both Have Same Sign */
1212
+ if (bit_offset == other_bit_offset) {
1213
+ return INT2FIX(0);
1214
+ } else if (bit_offset < other_bit_offset) {
1215
+ return INT2FIX(-1);
1216
+ } else {
1217
+ return INT2FIX(1);
1218
+ }
1219
+ } else {
1220
+ /* Different Signs */
1221
+ if (bit_offset == other_bit_offset) {
1222
+ return INT2FIX(0);
1223
+ } else if (bit_offset < other_bit_offset) {
1224
+ return INT2FIX(1);
1225
+ } else {
1226
+ return INT2FIX(-1);
1227
+ }
1228
+ }
1229
+ }
1230
+
1231
+ /* Structure constructor
1232
+ *
1233
+ * @param default_endianness [Symbol] Must be one of
1234
+ * {BinaryAccessor::ENDIANNESS}. By default it uses
1235
+ * BinaryAccessor::HOST_ENDIANNESS to determine the endianness of the host platform.
1236
+ * @param buffer [String] Buffer used to store the structure
1237
+ * @param item_class [Class] Class used to instantiate new structure items.
1238
+ * Must be StructureItem or one of its subclasses.
1239
+ */
1240
+ static VALUE structure_initialize(int argc, VALUE* argv, VALUE self) {
1241
+ volatile VALUE default_endianness = Qnil;
1242
+ volatile VALUE buffer = Qnil;
1243
+ volatile VALUE item_class = Qnil;
1244
+
1245
+ switch (argc)
1246
+ {
1247
+ case 0:
1248
+ default_endianness = HOST_ENDIANNESS;
1249
+ buffer = rb_str_new2("");
1250
+ item_class = cStructureItem;
1251
+ break;
1252
+ case 1:
1253
+ default_endianness = argv[0];
1254
+ buffer = rb_str_new2("");
1255
+ item_class = cStructureItem;
1256
+ break;
1257
+ case 2:
1258
+ default_endianness = argv[0];
1259
+ buffer = argv[1];
1260
+ item_class = cStructureItem;
1261
+ break;
1262
+ case 3:
1263
+ default_endianness = argv[0];
1264
+ buffer = argv[1];
1265
+ item_class = argv[2];
1266
+ break;
1267
+ default:
1268
+ /* Invalid number of arguments given */
1269
+ rb_raise(rb_eArgError, "wrong number of arguments (%d for 0..3)", argc);
1270
+ break;
1271
+ };
1272
+
1273
+ if ((default_endianness == symbol_BIG_ENDIAN) || (default_endianness == symbol_LITTLE_ENDIAN)) {
1274
+ rb_ivar_set(self, id_ivar_default_endianness, default_endianness);
1275
+ if (RTEST(buffer)) {
1276
+ Check_Type(buffer, T_STRING);
1277
+ rb_funcall(buffer, id_method_force_encoding, 1, ASCII_8BIT_STRING);
1278
+ rb_ivar_set(self, id_ivar_buffer, buffer);
1279
+ } else {
1280
+ rb_ivar_set(self, id_ivar_buffer, Qnil);
1281
+ }
1282
+ rb_ivar_set(self, id_ivar_item_class, item_class);
1283
+ rb_ivar_set(self, id_ivar_items, rb_hash_new());
1284
+ rb_ivar_set(self, id_ivar_sorted_items, rb_ary_new());
1285
+ rb_ivar_set(self, id_ivar_defined_length, INT2FIX(0));
1286
+ rb_ivar_set(self, id_ivar_defined_length_bits, INT2FIX(0));
1287
+ rb_ivar_set(self, id_ivar_pos_bit_size, INT2FIX(0));
1288
+ rb_ivar_set(self, id_ivar_neg_bit_size, INT2FIX(0));
1289
+ rb_ivar_set(self, id_ivar_fixed_size, Qtrue);
1290
+ rb_ivar_set(self, id_ivar_short_buffer_allowed, Qfalse);
1291
+ rb_ivar_set(self, id_ivar_mutex, Qnil);
1292
+ } else {
1293
+ rb_raise(rb_eArgError, "Unrecognized endianness: %s - Must be :BIG_ENDIAN or :LITTLE_ENDIAN", RSTRING_PTR(rb_funcall(default_endianness, id_method_to_s, 0)));
1294
+ }
1295
+
1296
+ return self;
1297
+ }
1298
+
1299
+ /*
1300
+ * Resize the buffer at least the defined length of the structure
1301
+ */
1302
+ static VALUE resize_buffer(VALUE self)
1303
+ {
1304
+ volatile VALUE buffer = rb_ivar_get(self, id_ivar_buffer);
1305
+ if (RTEST(buffer)) {
1306
+ volatile VALUE value_defined_length = rb_ivar_get(self, id_ivar_defined_length);
1307
+ long defined_length = FIX2INT(value_defined_length);
1308
+ long current_length = RSTRING_LEN(buffer);
1309
+
1310
+ /* Extend data size */
1311
+ if (current_length < defined_length)
1312
+ {
1313
+ rb_str_concat(buffer, rb_str_times(ZERO_STRING, INT2FIX(defined_length - current_length)));
1314
+ }
1315
+ }
1316
+
1317
+ return self;
1318
+ }
1319
+
1320
+ /*
1321
+ * Initialize all Packet methods
1322
+ */
1323
+ void Init_structure (void)
1324
+ {
1325
+ int zero = 0;
1326
+ volatile VALUE zero_string = Qnil;
1327
+ volatile VALUE ascii_8bit_string = Qnil;
1328
+
1329
+ mCosmos = rb_define_module("Cosmos");
1330
+ cBinaryAccessor = rb_define_class_under(mCosmos, "BinaryAccessor", rb_cObject);
1331
+
1332
+ id_method_to_s = rb_intern("to_s");
1333
+ id_method_raise_buffer_error = rb_intern("raise_buffer_error");
1334
+ id_method_read_array = rb_intern("read_array");
1335
+ id_method_force_encoding = rb_intern("force_encoding");
1336
+ id_method_freeze = rb_intern("freeze");
1337
+ id_method_slice = rb_intern("slice");
1338
+ id_method_reverse = rb_intern("reverse");
1339
+ id_method_Integer = rb_intern("Integer");
1340
+ id_method_Float = rb_intern("Float");
1341
+
1342
+ MIN_INT8 = INT2NUM(-128);
1343
+ MAX_INT8 = INT2NUM(127);
1344
+ MAX_UINT8 = INT2NUM(255);
1345
+ MIN_INT16 = INT2NUM(-32768);
1346
+ MAX_INT16 = INT2NUM(32767);
1347
+ MAX_UINT16 = INT2NUM(65535);
1348
+ MIN_INT32 = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(31));
1349
+ MIN_INT32 = rb_big_minus(TO_BIGNUM(INT2NUM(0)), MIN_INT32);
1350
+ MAX_INT32 = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(31));
1351
+ MAX_INT32 = rb_big_minus(TO_BIGNUM(MAX_INT32), INT2NUM(1));
1352
+ MAX_UINT32 = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(32));
1353
+ MAX_UINT32 = rb_big_minus(TO_BIGNUM(MAX_UINT32), INT2NUM(1));
1354
+ MIN_INT64 = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(63));
1355
+ MIN_INT64 = rb_big_minus(TO_BIGNUM(INT2NUM(0)), MIN_INT64);
1356
+ MAX_INT64 = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(63));
1357
+ MAX_INT64 = rb_big_minus(TO_BIGNUM(MAX_INT64), INT2NUM(1));
1358
+ MAX_UINT64 = rb_big_pow(TO_BIGNUM(INT2NUM(2)), INT2NUM(64));
1359
+ MAX_UINT64 = rb_big_minus(TO_BIGNUM(MAX_UINT64), INT2NUM(1));
1360
+ rb_define_const(cBinaryAccessor, "MIN_INT8", MIN_INT8);
1361
+ rb_define_const(cBinaryAccessor, "MAX_INT8", MAX_INT8);
1362
+ rb_define_const(cBinaryAccessor, "MAX_UINT8", MAX_UINT8);
1363
+ rb_define_const(cBinaryAccessor, "MIN_INT16", MIN_INT16);
1364
+ rb_define_const(cBinaryAccessor, "MAX_INT16", MAX_INT16);
1365
+ rb_define_const(cBinaryAccessor, "MAX_UINT16", MAX_UINT16);
1366
+ rb_define_const(cBinaryAccessor, "MIN_INT32", MIN_INT32);
1367
+ rb_define_const(cBinaryAccessor, "MAX_INT32", MAX_INT32);
1368
+ rb_define_const(cBinaryAccessor, "MAX_UINT32", MAX_UINT32);
1369
+ rb_define_const(cBinaryAccessor, "MIN_INT64", MIN_INT64);
1370
+ rb_define_const(cBinaryAccessor, "MAX_INT64", MAX_INT64);
1371
+ rb_define_const(cBinaryAccessor, "MAX_UINT64", MAX_UINT64);
1372
+
1373
+ id_ivar_buffer = rb_intern("@buffer");
1374
+ id_ivar_bit_offset = rb_intern("@bit_offset");
1375
+ id_ivar_bit_size = rb_intern("@bit_size");
1376
+ id_ivar_array_size = rb_intern("@array_size");
1377
+ id_ivar_endianness = rb_intern("@endianness");
1378
+ id_ivar_data_type = rb_intern("@data_type");
1379
+ id_ivar_default_endianness = rb_intern("@default_endianness");
1380
+ id_ivar_item_class = rb_intern("@item_class");
1381
+ id_ivar_items = rb_intern("@items");
1382
+ id_ivar_sorted_items = rb_intern("@sorted_items");
1383
+ id_ivar_defined_length = rb_intern("@defined_length");
1384
+ id_ivar_defined_length_bits = rb_intern("@defined_length_bits");
1385
+ id_ivar_pos_bit_size = rb_intern("@pos_bit_size");
1386
+ id_ivar_neg_bit_size = rb_intern("@neg_bit_size");
1387
+ id_ivar_fixed_size = rb_intern("@fixed_size");
1388
+ id_ivar_short_buffer_allowed = rb_intern("@short_buffer_allowed");
1389
+ id_ivar_mutex = rb_intern("@mutex");
1390
+
1391
+ symbol_LITTLE_ENDIAN = ID2SYM(rb_intern("LITTLE_ENDIAN"));
1392
+ symbol_BIG_ENDIAN = ID2SYM(rb_intern("BIG_ENDIAN"));
1393
+ symbol_INT = ID2SYM(rb_intern("INT"));
1394
+ symbol_UINT = ID2SYM(rb_intern("UINT"));
1395
+ symbol_FLOAT = ID2SYM(rb_intern("FLOAT"));
1396
+ symbol_STRING = ID2SYM(rb_intern("STRING"));
1397
+ symbol_BLOCK = ID2SYM(rb_intern("BLOCK"));
1398
+ symbol_DERIVED = ID2SYM(rb_intern("DERIVED"));
1399
+ symbol_read = ID2SYM(rb_intern("read"));
1400
+ symbol_write = ID2SYM(rb_intern("write"));
1401
+ symbol_TRUNCATE = ID2SYM(rb_intern("TRUNCATE"));
1402
+ symbol_SATURATE = ID2SYM(rb_intern("SATURATE"));
1403
+ symbol_ERROR = ID2SYM(rb_intern("ERROR"));
1404
+ symbol_ERROR_ALLOW_HEX = ID2SYM(rb_intern("ERROR_ALLOW_HEX"));
1405
+
1406
+ if ((*((char *) &endianness_check)) == 1) {
1407
+ HOST_ENDIANNESS = symbol_LITTLE_ENDIAN;
1408
+ } else {
1409
+ HOST_ENDIANNESS = symbol_BIG_ENDIAN;
1410
+ }
1411
+
1412
+ rb_define_singleton_method(cBinaryAccessor, "read", binary_accessor_read, 5);
1413
+ rb_define_singleton_method(cBinaryAccessor, "write", binary_accessor_write, 7);
1414
+
1415
+ cStructure = rb_define_class_under(mCosmos, "Structure", rb_cObject);
1416
+ id_const_ZERO_STRING = rb_intern("ZERO_STRING");
1417
+ zero_string = rb_str_new((char*) &zero, 1);
1418
+ rb_funcall(zero_string, id_method_freeze, 0);
1419
+ rb_const_set(cStructure, id_const_ZERO_STRING, zero_string);
1420
+ ZERO_STRING = rb_const_get(cStructure, id_const_ZERO_STRING);
1421
+ id_const_ASCII_8BIT_STRING = rb_intern("ASCII_8BIT_STRING");
1422
+ ascii_8bit_string = rb_str_new2("ASCII-8BIT");
1423
+ rb_funcall(ascii_8bit_string, id_method_freeze, 0);
1424
+ rb_const_set(cStructure, id_const_ASCII_8BIT_STRING, ascii_8bit_string);
1425
+ ASCII_8BIT_STRING = rb_const_get(cStructure, id_const_ASCII_8BIT_STRING);
1426
+ rb_define_method(cStructure, "initialize", structure_initialize, -1);
1427
+ rb_define_method(cStructure, "length", structure_length, 0);
1428
+ rb_define_method(cStructure, "read_item", read_item, -1);
1429
+ rb_define_method(cStructure, "resize_buffer", resize_buffer, 0);
1430
+
1431
+ cStructureItem = rb_define_class_under(mCosmos, "StructureItem", rb_cObject);
1432
+ rb_define_method(cStructureItem, "<=>", structure_item_spaceship, 1);
1433
+ }