Comments (6)
BTW, the module docstring should move to the very top of the file.
The version number should be defined before the imports.
from python-soundfile.
I think that the order of things in pysoundfile.py should be the order in which the file reads best.
The biggest issue with that are the CFFI declarations at the start of the file (the long string and the dictionaries). We could move those into their own file and import them from there.
After that, SoundFile
is really required knowledge in order to understand the functions. However, while this reads well if you read the source, it is not that important for the documentation. I would therefore propose to move SoundFile
to a different file as well. I think that we have reached a level of complexity that really warrants this. This also means that most of the libsndfile helpers have to move to soundfile.py as well, which cleans the main file from most of the underscore methods.
However, SoundFile
is still a very valuable API, and I still want to be able to from pysoundfile import SoundFile
, so we'll probably have to have some lengthy from soundfile import SoundFile, available_formats, available_subtypes, default_subtype, format_check
at the beginning of the file.
This would leave the main file pretty empty. But maybe that is not such a bad thing.
Any thoughts about this?
from python-soundfile.
I'm not sure if splitting pysoundfile
into several files is an improvement in the current state.
Having everything in one file also has its benefits.
The CFFI declarations are indeed annoying, but I'm hoping that some time in the future it will be possible to load a separate header file instead of copying the code. Then our code should become much cleaner.
After that,
SoundFile
is really required knowledge in order to understand the functions.
I'm not sure about that.
I guess it depends if you're trying to understand the thing in a bottom-up or a top-down way.
Both are valid viewpoints and the language itself allows both.
I stumbled upon a source file for CPython's open()
function.
In there, first the high-level open()
function is listed and only afterwards the classes which it needs (e.g. BufferedReader
) and all their base classes are defined.
Sure, a single example isn't quite representative, but probably we'll find more examples.
But anyway, the order of the Sphinx documentation is much more important than the order in the source file(s).
from python-soundfile.
Ordering functions before classes is fine by me.
I'll experiment with splitting pysoundfile into several files a bit. We'll see how it feels.
from python-soundfile.
The order was changed in #74.
Now the free functions come first, then comes the SoundFile
class, and finally the underscore-prefixed functions.
Within the class, there are first the "special" methods, then the "normal" methods and finally the underscore-prefixed methods.
Currently, I don't see a need for splitting the code into several modules.
I vote for closing this issue.
from python-soundfile.
I agree.
from python-soundfile.
Related Issues (20)
- numpy is a dependency, but this is not declared HOT 3
- Feature request: Support interleaved stereo data HOT 4
- buffer_read doesn't work in basic test HOT 2
- Soundfile read/write wav is not symmetric with default arguments HOT 3
- module 'soundfile' has no attribute 'SoundFileRuntimeError' HOT 5
- Value Error: array is too big when loading .flac file
- soundfile crashes when trying to export long .ogg file HOT 1
- soundfile.LibsndfileError: Error opening <_io.BytesIO object at 0x0000022B81C21850>: Format not recognised. HOT 2
- Cannot suppress warnings when decoding mp3
- Cannot open Ogg FLAC file: unknown error in flac decoder HOT 1
- miniforge3/lib/python3.9/site-packages/soundfile.py", line 1229, in _init_virtual_io def vio_get_filelen(user_data): MemoryError: Cannot allocate write+execute memory for ffi.callback(). You might be running on a system that prevents this. For more information, see https://cffi.readthedocs.io/en/latest/using.html#callbacks
- Cannot write Ogg files over 96 seconds long at 44.1 kHz HOT 4
- soundfile.info does not work on mp3 HOT 2
- soundfile.LibsndfileError: <exception str() failed> HOT 6
- How to save left and right channel in separate files? HOT 1
- soundfile.LibsndfileError: Error : unknown error in flac decoder. HOT 2
- "Format not recognised." for m4a files HOT 2
- soundfile.LibsndfileError: Error opening <tempfile._TemporaryFileWrapper object at 0x7feadae59070>: Format not recognised. HOT 2
- Part of mp3 is loaded. HOT 2
- unknown error in flac decoder HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from python-soundfile.