/HID_Descriptor_tool

a HID PID descriptor tool for generating force feedback devices' descriptor

Primary LanguageC

HID-PID Descriptor tool

an extendable hid descriptor tool, implements a free conversion between hexdemical codes, data structure definition and the report descriptor written in natural language.

Files

  • \rptDsc:
    To get syntax highlighting, in Windows copy this to "C:\Users\Administrator\AppData\Roaming\Sublime Text 3\Packages\User", then choose language "rptDsc" when editing with Sublime Text 3.
  • HID_PID_Definitions.py:
    Human Interface Device & Physical Interface Device usage definitions.
  • DscToHex.py:
    parses the .rptDsc(report descriptor) into hexdemical codes.
  • DscToDataStructuren.py:
    parses the .rptDsc into c language data structure definitions.
  • HexToString.py:
    parses the hexdemical codes to the report descriptor written in natural language.

How to Use

  • Before writing report descriptor in DscInput.rptDsc, you are recommended to copy \rptDsc to the path refered above so that syntax highlight can work. To parse the descriptor into bytes run DescriptorGenTool, to parse into c language data structure run DataStructureGen.py.

Parser Limitations

For the purpose of freeing developers from the tedious and error prone works of writing the Report Descriptor or the data structure attached to it, i made this parser. However, the USB HID Report Descriptor itself was rather a flexible protocol. There is no perfect approach to an easy solution of all the problems we meet in developing.

bugs been found:

  • c doesn't support usage like "enum XXX : _type {...}" to designate specific type to the enum.

Screenshots

editing report descriptor in sublime text:

reportDescriptor.png

get parsed bytes from report descriptor:

outputBytes.png

get c data structure definitions from report descriptor:

dataStructure.png