642 |
} |
} |
643 |
|
|
644 |
// Write the file. |
// Write the file. |
645 |
int iErrors = 0; |
int iErrors = 0; |
646 |
QTextStream ts(&file); |
QTextStream ts(&file); |
647 |
ts << "# " << QSAMPLER_TITLE " - " << tr(QSAMPLER_SUBTITLE) << endl; |
ts << "# " << QSAMPLER_TITLE " - " << tr(QSAMPLER_SUBTITLE) << endl; |
648 |
ts << "# " << tr("Version") |
ts << "# " << tr("Version") |
653 |
ts << "# " << tr("File") |
ts << "# " << tr("File") |
654 |
<< ": " << QFileInfo(sFilename).fileName() << endl; |
<< ": " << QFileInfo(sFilename).fileName() << endl; |
655 |
ts << "# " << tr("Date") |
ts << "# " << tr("Date") |
656 |
<< ": " << QDate::currentDate().toString("MMMM dd yyyy") |
<< ": " << QDate::currentDate().toString("MMM dd yyyy") |
657 |
<< " " << QTime::currentTime().toString("hh:mm:ss") << endl; |
<< " " << QTime::currentTime().toString("hh:mm:ss") << endl; |
658 |
ts << "#" << endl; |
ts << "#" << endl; |
659 |
ts << endl; |
ts << endl; |
660 |
|
// It is assumed that this new kind of device+session file |
661 |
|
// will be loaded from a complete |
662 |
|
int *piDeviceIDs; |
663 |
|
int iDevice; |
664 |
|
ts << "RESET" << endl; |
665 |
|
// Audio device mapping. |
666 |
|
QMap<int, int> audioDeviceMap; |
667 |
|
piDeviceIDs = qsamplerDevice::getDevices(m_pClient, qsamplerDevice::Audio); |
668 |
|
for (iDevice = 0; piDeviceIDs && piDeviceIDs[iDevice] >= 0; iDevice++) { |
669 |
|
qsamplerDevice device(m_pClient, qsamplerDevice::Audio, piDeviceIDs[iDevice]); |
670 |
|
ts << endl; |
671 |
|
ts << "# " << device.deviceTypeName() << " " << device.driverName() |
672 |
|
<< " " << tr("Device") << " " << iDevice << endl; |
673 |
|
ts << "CREATE AUDIO_OUTPUT_DEVICE " << device.driverName(); |
674 |
|
qsamplerDeviceParamMap& params = device.params(); |
675 |
|
qsamplerDeviceParamMap::ConstIterator iter; |
676 |
|
for (iter = params.begin(); iter != params.end(); ++iter) |
677 |
|
ts << " " << iter.key() << "='" << iter.data().value << "'"; |
678 |
|
ts << endl; |
679 |
|
audioDeviceMap[device.deviceID()] = iDevice; |
680 |
|
// Try to keep it snappy :) |
681 |
|
QApplication::eventLoop()->processEvents(QEventLoop::ExcludeUserInput); |
682 |
|
} |
683 |
|
// MIDI device mapping. |
684 |
|
QMap<int, int> midiDeviceMap; |
685 |
|
piDeviceIDs = qsamplerDevice::getDevices(m_pClient, qsamplerDevice::Midi); |
686 |
|
for (iDevice = 0; piDeviceIDs && piDeviceIDs[iDevice] >= 0; iDevice++) { |
687 |
|
qsamplerDevice device(m_pClient, qsamplerDevice::Midi, piDeviceIDs[iDevice]); |
688 |
|
ts << "# " << device.deviceTypeName() << " " << device.driverName() |
689 |
|
<< " " << tr("Device") << " " << iDevice << endl; |
690 |
|
ts << "CREATE MIDI_INPUT_DEVICE " << device.driverName(); |
691 |
|
qsamplerDeviceParamMap& params = device.params(); |
692 |
|
qsamplerDeviceParamMap::ConstIterator iter; |
693 |
|
for (iter = params.begin(); iter != params.end(); ++iter) |
694 |
|
ts << " " << iter.key() << "='" << iter.data().value << "'"; |
695 |
|
ts << endl; |
696 |
|
midiDeviceMap[device.deviceID()] = iDevice; |
697 |
|
// Try to keep it snappy :) |
698 |
|
QApplication::eventLoop()->processEvents(QEventLoop::ExcludeUserInput); |
699 |
|
} |
700 |
|
ts << endl; |
701 |
|
// Sampler channel mapping. |
702 |
QWidgetList wlist = m_pWorkspace->windowList(); |
QWidgetList wlist = m_pWorkspace->windowList(); |
703 |
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) { |
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) { |
704 |
qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel); |
qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel); |
705 |
if (pChannelStrip) { |
if (pChannelStrip) { |
706 |
qsamplerChannel *pChannel = pChannelStrip->channel(); |
qsamplerChannel *pChannel = pChannelStrip->channel(); |
707 |
if (pChannel) { |
if (pChannel) { |
708 |
ts << "# Channel " << iChannel << endl; |
ts << "# " << tr("Channel") << " " << iChannel << endl; |
709 |
ts << "ADD CHANNEL" << endl; |
ts << "ADD CHANNEL" << endl; |
710 |
ts << "SET CHANNEL AUDIO_OUTPUT_TYPE " << iChannel << " " << pChannel->audioDriver() << endl; |
if (audioDeviceMap.isEmpty()) { |
711 |
ts << "SET CHANNEL MIDI_INPUT_TYPE " << iChannel << " " << pChannel->midiDriver() << endl; |
ts << "SET CHANNEL AUDIO_OUTPUT_TYPE " << iChannel |
712 |
// ts << "SET CHANNEL MIDI_INPUT_PORT " << iChannel << " " << pChannel->midiPort() << endl; |
<< " " << pChannel->audioDriver() << endl; |
713 |
|
} else { |
714 |
|
ts << "SET CHANNEL AUDIO_OUTPUT_DEVICE " << iChannel |
715 |
|
<< " " << audioDeviceMap[pChannel->audioDevice()] << endl; |
716 |
|
} |
717 |
|
if (midiDeviceMap.isEmpty()) { |
718 |
|
ts << "SET CHANNEL MIDI_INPUT_TYPE " << iChannel |
719 |
|
<< " " << pChannel->midiDriver() << endl; |
720 |
|
} else { |
721 |
|
ts << "SET CHANNEL MIDI_INPUT_DEVICE " << iChannel |
722 |
|
<< " " << midiDeviceMap[pChannel->midiDevice()] << endl; |
723 |
|
} |
724 |
|
ts << "SET CHANNEL MIDI_INPUT_PORT " << iChannel |
725 |
|
<< " " << pChannel->midiPort() << endl; |
726 |
ts << "SET CHANNEL MIDI_INPUT_CHANNEL " << iChannel << " "; |
ts << "SET CHANNEL MIDI_INPUT_CHANNEL " << iChannel << " "; |
727 |
if (pChannel->midiChannel() == LSCP_MIDI_CHANNEL_ALL) |
if (pChannel->midiChannel() == LSCP_MIDI_CHANNEL_ALL) |
728 |
ts << "ALL"; |
ts << "ALL"; |