Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Reopen PR.
The poing is now SegyIO assumes that all SEGY are big endian.
It doesn't work with little endian.
Moreover it doesn't check the endianness of the machine.
This PR aims to check whether endianness of the machine and SEGY file are different or not.
Based on this we should make a decision whether to swap bytes or not.
Swap bytes or not depends on the value in file binary header 3224-3225 bytes (Data Sample Format).
This header is mandatory for all SEGY.
It must be in range [1,16].
If not -> then swap bytes and check again.
Also it is important to be careful with IBM32 format.
Does the function ntoh in IBM32->FLOAT32 converter works as expected on both BIG and LITTLE endian machines?
Finally we have to check carefully the following cases:
My machines are LE only :)