aboutsummaryrefslogtreecommitdiff
path: root/modules/chibi/cp_instrument.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--modules/chibi/cp_instrument.cpp299
1 files changed, 137 insertions, 162 deletions
diff --git a/modules/chibi/cp_instrument.cpp b/modules/chibi/cp_instrument.cpp
index 606a4217e..187a1ab7f 100644
--- a/modules/chibi/cp_instrument.cpp
+++ b/modules/chibi/cp_instrument.cpp
@@ -27,308 +27,285 @@
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/*************************************************************************/
#include "cp_instrument.h"
-#include "cp_song.h"
#include "cp_note.h"
-
-
+#include "cp_song.h"
const char *CPInstrument::get_name() {
return name;
-
}
void CPInstrument::set_name(const char *p_name) {
-
-
- if (p_name==NULL) {
- name[0]=0;
+
+ if (p_name == NULL) {
+ name[0] = 0;
return;
}
-
-
- bool done=false;
- for (int i=0;i<MAX_NAME_LEN;i++) {
-
-
- name[i]=done?0:p_name[i];
- if (!done && p_name[i]==0)
- done=true;
+
+ bool done = false;
+ for (int i = 0; i < MAX_NAME_LEN; i++) {
+
+ name[i] = done ? 0 : p_name[i];
+ if (!done && p_name[i] == 0)
+ done = true;
}
-
- name[MAX_NAME_LEN-1]=0; /* just in case */
-
-
+
+ name[MAX_NAME_LEN - 1] = 0; /* just in case */
}
-void CPInstrument::set_sample_number(uint8_t p_note,uint8_t p_sample_id) {
-
- CP_ERR_COND(p_note>=CPNote::NOTES);
- CP_ERR_COND(p_sample_id>CPSong::MAX_SAMPLES && p_sample_id!=CPNote::EMPTY);
- data.sample_number[p_note]=p_sample_id;
-
-
+void CPInstrument::set_sample_number(uint8_t p_note, uint8_t p_sample_id) {
+
+ CP_ERR_COND(p_note >= CPNote::NOTES);
+ CP_ERR_COND(p_sample_id > CPSong::MAX_SAMPLES && p_sample_id != CPNote::EMPTY);
+ data.sample_number[p_note] = p_sample_id;
}
uint8_t CPInstrument::get_sample_number(uint8_t p_note) {
-
- CP_ERR_COND_V(p_note>=CPNote::NOTES,0);
+
+ CP_ERR_COND_V(p_note >= CPNote::NOTES, 0);
return data.sample_number[p_note];
}
-void CPInstrument::set_note_number(uint8_t p_note,uint8_t p_note_id) {
-
- CP_ERR_COND(p_note>=CPNote::NOTES);
- CP_ERR_COND(p_note_id>=CPNote::NOTES && p_note_id!=CPNote::EMPTY);
- data.note_number[p_note]=p_note_id;
-
+void CPInstrument::set_note_number(uint8_t p_note, uint8_t p_note_id) {
+
+ CP_ERR_COND(p_note >= CPNote::NOTES);
+ CP_ERR_COND(p_note_id >= CPNote::NOTES && p_note_id != CPNote::EMPTY);
+ data.note_number[p_note] = p_note_id;
}
uint8_t CPInstrument::get_note_number(uint8_t p_note) {
-
- CP_ERR_COND_V(p_note>=CPNote::NOTES,0);
+
+ CP_ERR_COND_V(p_note >= CPNote::NOTES, 0);
return data.note_number[p_note];
-
}
void CPInstrument::set_NNA_type(NNA_Type p_NNA_type) {
-
- data.NNA_type=p_NNA_type;
+
+ data.NNA_type = p_NNA_type;
}
CPInstrument::NNA_Type CPInstrument::get_NNA_type() {
-
+
return data.NNA_type;
}
void CPInstrument::set_DC_type(DC_Type p_DC_type) {
-
- data.DC_type=p_DC_type;
+
+ data.DC_type = p_DC_type;
}
CPInstrument::DC_Type CPInstrument::get_DC_type() {
-
+
return data.DC_type;
-
}
-
+
void CPInstrument::set_DC_action(DC_Action p_DC_action) {
-
- data.DC_action=p_DC_action;
+
+ data.DC_action = p_DC_action;
}
CPInstrument::DC_Action CPInstrument::get_DC_action() {
-
+
return data.DC_action;
}
-/* Volume */
+/* Volume */
void CPInstrument::set_volume_global_amount(uint8_t p_amount) {
-
- CP_ERR_COND(p_amount>MAX_VOLUME);
- data.volume.global_amount=p_amount;
-
+
+ CP_ERR_COND(p_amount > MAX_VOLUME);
+ data.volume.global_amount = p_amount;
}
uint8_t CPInstrument::get_volume_global_amount() {
-
+
return data.volume.global_amount;
}
void CPInstrument::set_volume_fadeout(uint16_t p_amount) {
- CP_ERR_COND(p_amount>MAX_FADEOUT);
- data.volume.fadeout=p_amount;
+ CP_ERR_COND(p_amount > MAX_FADEOUT);
+ data.volume.fadeout = p_amount;
}
uint16_t CPInstrument::get_volume_fadeout() {
-
+
return data.volume.fadeout;
}
void CPInstrument::set_volume_random_variation(uint8_t p_amount) {
-
- CP_ERR_COND(p_amount>MAX_VOLUME_RANDOM);
- data.volume.random_variation=p_amount;
+
+ CP_ERR_COND(p_amount > MAX_VOLUME_RANDOM);
+ data.volume.random_variation = p_amount;
}
uint8_t CPInstrument::get_volume_random_variation() {
-
+
return data.volume.random_variation;
}
-
+
/* Panning */
void CPInstrument::set_pan_default_amount(uint8_t p_amount) {
-
- CP_ERR_COND(p_amount>MAX_PAN);
- data.pan.default_amount=p_amount;
+
+ CP_ERR_COND(p_amount > MAX_PAN);
+ data.pan.default_amount = p_amount;
}
uint8_t CPInstrument::get_pan_default_amount() {
-
+
return data.pan.default_amount;
}
void CPInstrument::set_pan_default_enabled(bool p_enabled) {
-
- data.pan.use_default=p_enabled;
+
+ data.pan.use_default = p_enabled;
}
bool CPInstrument::is_pan_default_enabled() {
-
+
return data.pan.use_default;
-
}
void CPInstrument::set_pan_pitch_separation(int8_t p_amount) {
-
- CP_ERR_COND(p_amount<-32);
- CP_ERR_COND(p_amount>32);
- data.pan.pitch_separation=p_amount;
+
+ CP_ERR_COND(p_amount < -32);
+ CP_ERR_COND(p_amount > 32);
+ data.pan.pitch_separation = p_amount;
}
int8_t CPInstrument::get_pan_pitch_separation() {
-
+
return data.pan.pitch_separation;
}
void CPInstrument::set_pan_pitch_center(uint8_t p_amount) {
-
- CP_ERR_COND(p_amount>=CPNote::NOTES);
- data.pan.pitch_center=p_amount;
+
+ CP_ERR_COND(p_amount >= CPNote::NOTES);
+ data.pan.pitch_center = p_amount;
}
uint8_t CPInstrument::get_pan_pitch_center() {
-
+
return data.pan.pitch_center;
}
void CPInstrument::set_pan_random_variation(uint8_t p_amount) {
-
- CP_ERR_COND(p_amount>MAX_PAN_RANDOM);
- data.pan.random_variation=p_amount;
+
+ CP_ERR_COND(p_amount > MAX_PAN_RANDOM);
+ data.pan.random_variation = p_amount;
}
uint8_t CPInstrument::get_pan_random_variation() {
-
+
return data.pan.random_variation;
}
/* Pitch / Filter */
void CPInstrument::set_pitch_use_as_filter(bool p_enabled) {
-
- data.pitch.use_as_filter=p_enabled;
+
+ data.pitch.use_as_filter = p_enabled;
}
bool CPInstrument::is_pitch_use_as_filter() {
-
+
return data.pitch.use_as_filter;
}
void CPInstrument::set_filter_use_default_cutoff(bool p_enabled) {
-
- data.pitch.use_default_cutoff=p_enabled;
+ data.pitch.use_default_cutoff = p_enabled;
}
bool CPInstrument::filter_use_default_cutoff() {
-
+
return data.pitch.use_default_cutoff;
}
void CPInstrument::set_filter_default_cutoff(uint8_t p_amount) {
-
- CP_ERR_COND(p_amount>MAX_FILTER_CUTOFF);
- data.pitch.default_cutoff=p_amount;
+
+ CP_ERR_COND(p_amount > MAX_FILTER_CUTOFF);
+ data.pitch.default_cutoff = p_amount;
}
uint8_t CPInstrument::get_filter_default_cutoff() {
-
+
return data.pitch.default_cutoff;
}
void CPInstrument::set_filter_use_default_resonance(bool p_enabled) {
-
- data.pitch.use_default_resonance=p_enabled;
+
+ data.pitch.use_default_resonance = p_enabled;
}
bool CPInstrument::filter_use_default_resonance() {
-
+
return data.pitch.use_default_resonance;
}
void CPInstrument::set_filter_default_resonance(uint8_t p_amount) {
-
- CP_ERR_COND(p_amount>MAX_FILTER_RESONANCE);
- data.pitch.default_resonance=p_amount;
-
+
+ CP_ERR_COND(p_amount > MAX_FILTER_RESONANCE);
+ data.pitch.default_resonance = p_amount;
}
uint8_t CPInstrument::get_filter_default_resonance() {
-
+
return data.pitch.default_resonance;
}
/* Envelopes */
+CPEnvelope *CPInstrument::get_volume_envelope() {
-CPEnvelope* CPInstrument::get_volume_envelope() {
-
return &data.volume.envelope;
}
-CPEnvelope* CPInstrument::get_pan_envelope() {
-
- return &data.pan.envelope;
-}
-CPEnvelope* CPInstrument::get_pitch_filter_envelope() {
-
- return &data.pitch.envelope;
-
-
+CPEnvelope *CPInstrument::get_pan_envelope() {
+
+ return &data.pan.envelope;
}
+CPEnvelope *CPInstrument::get_pitch_filter_envelope() {
+ return &data.pitch.envelope;
+}
void CPInstrument::reset() {
-
- name[0]=0;
-
- data.NNA_type=NNA_NOTE_CUT;
- data.DC_action=DCA_NOTE_CUT;
- data.DC_type=DCT_DISABLED;
-
- for (int i=0;i<CPNote::NOTES;i++) {
-
- data.sample_number[i]=CPNote::EMPTY;
- data.note_number[i]=i;
+
+ name[0] = 0;
+
+ data.NNA_type = NNA_NOTE_CUT;
+ data.DC_action = DCA_NOTE_CUT;
+ data.DC_type = DCT_DISABLED;
+
+ for (int i = 0; i < CPNote::NOTES; i++) {
+
+ data.sample_number[i] = CPNote::EMPTY;
+ data.note_number[i] = i;
}
-
+
data.volume.envelope.reset();
data.volume.envelope.set_max(64);
data.volume.envelope.set_min(0);
- data.volume.envelope.add_position(0,64,false);
- data.volume.envelope.add_position(30,64,false);
-
- data.volume.global_amount=MAX_VOLUME;
- data.volume.fadeout=0;
- data.volume.random_variation=0;
-
+ data.volume.envelope.add_position(0, 64, false);
+ data.volume.envelope.add_position(30, 64, false);
+
+ data.volume.global_amount = MAX_VOLUME;
+ data.volume.fadeout = 0;
+ data.volume.random_variation = 0;
+
data.pan.envelope.reset();
data.pan.envelope.set_max(32);
data.pan.envelope.set_min(-32);
- data.pan.envelope.add_position(0,0,false);
- data.pan.envelope.add_position(30,0,false);
-
- data.pan.default_amount=32;
- data.pan.pitch_center=48;
- data.pan.pitch_separation=0;
- data.pan.use_default=false;
- data.pan.random_variation=0;
-
-
+ data.pan.envelope.add_position(0, 0, false);
+ data.pan.envelope.add_position(30, 0, false);
+
+ data.pan.default_amount = 32;
+ data.pan.pitch_center = 48;
+ data.pan.pitch_separation = 0;
+ data.pan.use_default = false;
+ data.pan.random_variation = 0;
+
data.pitch.envelope.reset();
data.pitch.envelope.set_max(32);
data.pitch.envelope.set_min(-32);
- data.pitch.envelope.add_position(0,0,false);
- data.pitch.envelope.add_position(30,0,false);
- data.pitch.use_as_filter=false;
- data.pitch.use_default_cutoff=false;
- data.pitch.use_default_resonance=false;
- data.pitch.default_cutoff=0;
- data.pitch.default_resonance=0;
-
+ data.pitch.envelope.add_position(0, 0, false);
+ data.pitch.envelope.add_position(30, 0, false);
+ data.pitch.use_as_filter = false;
+ data.pitch.use_default_cutoff = false;
+ data.pitch.use_default_resonance = false;
+ data.pitch.default_cutoff = 0;
+ data.pitch.default_resonance = 0;
}
bool CPInstrument::is_empty() {
-
- bool has_sample=false;
-
- for (int i=0;i<CPNote::NOTES;i++) {
-
- if (data.sample_number[i]!=CPNote::EMPTY) {
-
- has_sample=true;
+
+ bool has_sample = false;
+
+ for (int i = 0; i < CPNote::NOTES; i++) {
+
+ if (data.sample_number[i] != CPNote::EMPTY) {
+
+ has_sample = true;
break;
}
}
@@ -337,8 +314,6 @@ bool CPInstrument::is_empty() {
}
CPInstrument::CPInstrument() {
-
+
reset();
-
}
-