Struct reader Amanuensis  Struct reader Amanuensis

This essay does not describe an existing computer program, just one that should exist. This essay is about a suggested student project in Java programming. This essay gives a rough overview of how it might work. I have no source, object, specifications, file layouts or anything else useful to implementing this project.

This project outline is not like the artificial, tidy little problems you are spoon-fed in school, when all the facts you need are included, nothing extraneous is mentioned, the answer is fully specified, along with hints to nudge you toward a single expected canonical solution. This project is much more like the real world of messy problems where it is up to you to fully the define the end point, or a series of ever more difficult versions of this project, and research the information yourself to solve them.

Everything I have to say to help you with this project is written below. I am not prepared to help you implement it; or give you any additional materials. I have too many other projects of my own.

Though I am a programmer, I don’t do people’s homework for them. That just robs them of an education.

You have my full permission to implement this project in any way you please and to keep all the profits from your endeavour.

Please do not email me about this project without reading the disclaimer above.

This is one of the amanuensis projects. Another boring task is writing code to read and write C structures using LEDataInputStream and DataInputStream. See the File I/O Amanuensis for the general idea. You would either:
  1. Feed it a C/C++ declaration, analyse it with a parser (see parser in the glossary) and have it generate a set of Java source code class declarations, and the read and write method to read one struct.
  2. Check off the types and names of the various fields in a dialog box, creating a binary record descriptor. Use this to generate a C++ struct source code and the set of Java source code class declarations, and the read and write method to read one struct.
  3. Use reflection to discover the structure of the Java class which may have embedded references. You need to create a fixed length record, so you must presume each reference field is not null, and you also need caps on the lengths of String fields.
Even if you can’t get it perfect, and just throw up your hands at the problem of references and variable length Strings, you can still save a lot of the bullwork. You can always manually touch up the crude source code you generate.

A more efficient variant would generate code to read entire records into a byte array, then generate get/put accessor functions to read/write the various fields. The accessor would have to construct the binary value by shift and logical or of the bytes at the corresponding offsets in the byte array, using logic similar to that in LEDataInputStream and LEDataOutputStream.

LeDataStream
Reading C Structs

CMP homejump to top You can get the freshest copy of this page from: or possibly from your local J: drive (Java virtual drive/mindprod.com website mirror)
http://mindprod.com/project/structreaderamanuensis.html J:\mindprod\project\structreaderamanuensis.html
logo
Please email your , letters to the editor, errors, omissions, typos, formatting errors, ambiguities, unclear wording, broken/redirected link reports, suggestions to improve this page or comments to Roedy Green : feedback email. If you want your message, your name or email kept confidential, not considered for public posting, please explicitly specify that. Unless you state otherwise, I will treat your message as a letter to the editor that I may or may not publish in the feedback section. After that, it will be too late to retract it. If you disagree with something I said, please quote it and cite the web page where you found it, tell me why you think it is wrong, and, if possible, provide some supporting evidence. Threatening to kill me or spouting obscenities has yet to persuade me to change my mind.
mindprod.com IP:[65.110.21.43]
view BlogYour face IP:[38.107.179.210]
You are visitor number 5,612.