You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
2.4 KiB
71 lines
2.4 KiB
#! /usr/bin/env python3
|
|
# -*- coding: utf-8 -*-
|
|
"""
|
|
Copyright 2022, Nils Hilbricht, Germany ( https://www.hilbricht.net )
|
|
|
|
This file is part of the Laborejo Software Suite ( https://www.laborejo.org ),
|
|
|
|
This application is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
"""
|
|
|
|
|
|
import logging; logger = logging.getLogger(__name__); logger.info("import")
|
|
|
|
|
|
class Data(object):
|
|
"""Base class to all Data. Data is the class that gets added to the session. Consider this an
|
|
interface. It can be used as an object or parent class to get a working program, even if it
|
|
doesn't do much.
|
|
"""
|
|
|
|
def __init__(self, parentSession):
|
|
self.parentSession = parentSession
|
|
super().__init__()
|
|
|
|
def updateJackMetadataSorting(self):
|
|
pass
|
|
|
|
def getMidiInputNameAndUuid(self):
|
|
"""
|
|
Return name and cboxMidiPortUid.
|
|
name is Client:Port JACK format
|
|
|
|
Reimplement this in your actual data classes like sf2_sampler and sfz_sampler and
|
|
sequencers. Used by the quick connect midi input widget.
|
|
If double None as return the widget in the GUI might hide and deactivate itself."""
|
|
|
|
return None, None
|
|
|
|
#Save / Load / Export
|
|
def serialize(self)->dict:
|
|
return {
|
|
}
|
|
|
|
@classmethod
|
|
def instanceFromSerializedData(cls, parentSession, serializedData):
|
|
"""The entry function to create a score from saved data. It is called by the session.
|
|
|
|
This functions triggers a tree of other createInstanceFromSerializedData which finally
|
|
return the score, which gets saved in the session.
|
|
|
|
The serializedData is already converted to primitive python types from json,
|
|
but nothing more. Here we create the actual objects."""
|
|
self = cls(parentSession=parentSession,
|
|
)
|
|
|
|
return self
|
|
|
|
def export(self)->dict:
|
|
return {
|
|
}
|
|
|