Skip to content

Commit

Permalink
tweak how versioning is handled, add BUNGEE_API atrributes
Browse files Browse the repository at this point in the history
  • Loading branch information
kupix committed Apr 12, 2024
1 parent ea7080f commit db27b41
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 12 deletions.
24 changes: 13 additions & 11 deletions bungee/Bungee.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,11 @@
#include <cmath>
#include <cstdint>

#define BUNGEE_API __attribute__((visibility("default")))

namespace Bungee {

const char *version();
BUNGEE_API const char *version();

struct Request
{
Expand Down Expand Up @@ -44,7 +46,7 @@ struct InputChunk
// Sample positions relative to the start of the audio track
int begin, end;

int frameCount() const
BUNGEE_API int frameCount() const
{
return end - begin;
}
Expand Down Expand Up @@ -75,37 +77,37 @@ struct Stretcher
struct Implementation;
Implementation *const state;

Stretcher(SampleRates sampleRates, int channelCount);
BUNGEE_API Stretcher(SampleRates sampleRates, int channelCount);

~Stretcher();
BUNGEE_API ~Stretcher();

// Returns the largest number of frames that might be requested by specifyGrain()
// This helps the caller to allocate large enough buffers because it is guaranteed that
// InputChunk::frameCount() will not exceed this number.
int maxInputFrameCount() const;
BUNGEE_API int maxInputFrameCount() const;

// This function adjusts request.position so that the stretcher has a run in of a few
// grains before hitting the requested position. Without preroll, the first milliseconds
// of audio might sound weak or initial transients might be lost.
void preroll(Request &request) const;
BUNGEE_API void preroll(Request &request) const;

// This function prepares request.position and request.reset for the subsequent grain.
// Typically called within a granular loop where playback at constant request.speed is desired.
void next(Request &request) const;
BUNGEE_API void next(Request &request) const;

// Specify a grain of audio and compute the necessary segment of input audio.
// After calling this function, call analyseGrain.
InputChunk specifyGrain(const Request &request);
BUNGEE_API InputChunk specifyGrain(const Request &request);

// Begins processing the grain. The audio data should correspond to the range
// specified by specifyGrain's return value. After calling this function, call synthesiseGrain.
void analyseGrain(const float *data, intptr_t channelStride);
BUNGEE_API void analyseGrain(const float *data, intptr_t channelStride);

// Complete processing of the grain of audio that was previously set up with calls to specifyGrain and analyseGrain.
void synthesiseGrain(OutputChunk &outputChunk);
BUNGEE_API void synthesiseGrain(OutputChunk &outputChunk);

// Returns true if every grain in the stretcher's pipeline is invalid (its Request::position was NaN).
bool isFlushed() const;
BUNGEE_API bool isFlushed() const;
};

} // namespace Bungee
7 changes: 7 additions & 0 deletions src/Stretcher.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,13 @@

namespace Bungee {

extern const char *versionDescription;

const char *version()
{
return versionDescription;
}

Stretcher::Stretcher(SampleRates sampleRates, int channelCount) :
state(new Implementation(sampleRates, channelCount))
{
Expand Down
2 changes: 1 addition & 1 deletion version.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ else()
string(STRIP "${GIT_DESCRIBE}" GIT_DESCRIBE)
endif()

set(CONTENTS "namespace ${VERSION_NAMESPACE} { const char *version() { return \"${GIT_DESCRIBE}\";} }")
set(CONTENTS "namespace ${VERSION_NAMESPACE} { const char *versionDescription = \"${GIT_DESCRIBE}\"; }")

if(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/version-backup/version.cpp)
file(READ ${CMAKE_CURRENT_SOURCE_DIR}/version-backup/version.cpp EXISTING_CONTENTS)
Expand Down

0 comments on commit db27b41

Please sign in to comment.