Audio-Nama
view release on metacpan or search on metacpan
lib/Audio/Nama/Bus.pm view on Meta::CPAN
and ! $Audio::Nama::mode->preview and ! $Audio::Nama::mode->doodle;
} grep {$_->rec_status ne OFF} $bus->track_o;
}
sub remove {
my $bus = shift;
# all tracks returned to Main group
map{$_->set(group => 'Main') } $bus->track_o;
my $mix_track = $Audio::Nama::tn{$bus->name};
# remove mix track unless it has some WAV files
$mix_track->remove if defined $mix_track and not scalar @{ $mix_track->versions };
# remove bus from index
delete $Audio::Nama::bn{$bus->name};
}
sub wantme {
my $bus = shift;
no warnings 'uninitialized';
my @wantme = grep{ $_->{rw} =~ /REC|MON/
and $_->source_type eq 'bus'
and $_->source_id eq $bus->name
and $_->is_used} Audio::Nama::all_tracks();
@wantme
}
}
{
package Audio::Nama::SendBusRaw;
use v5.36; use Carp; our @ISA = 'Audio::Nama::Bus';
our $VERSION = 1.0;
use Audio::Nama::Log qw(logsub logpkg);
sub apply {
my $bus = shift;
map{
my @input_path = $_->input_path;
$Audio::Nama::g->add_edge(@input_path);
$Audio::Nama::g->set_edge_attributes( @input_path,
{ width => $Audio::Nama::tn{$_->target}->width });
my @edge = ($_->name, Audio::Nama::output_node($bus->send_type));
$Audio::Nama::g->add_edge(@edge);
$Audio::Nama::g->set_edge_attributes( @edge, {
send_id => $bus->send_id,
width => 2 }); # force to stereo
} grep{ $_->input_path } $bus->track_o;
}
sub remove {
my $bus = shift;
# delete all tracks
map{$_->remove } $bus->track_o;
# remove bus
delete $by_name{$bus->name};
}
}
{
package Audio::Nama::SendBusCooked;
use Audio::Nama::Log qw(logsub logpkg);
use v5.36; use Carp; our @ISA = 'Audio::Nama::SendBusRaw';
our $VERSION = 1.0;
# graphic routing: target -> slave -> bus_send_type
sub apply {
my $bus = shift;
my $g = shift;
map{ my @edge = ($_->name, Audio::Nama::output_node($bus->send_type));
$g->add_path( $_->target, @edge);
$g->set_edge_attributes( @edge, {
send_type => $bus->send_type,
send_id => $bus->send_id,
width => 2})
} $bus->track_o;
}
}
{
package Audio::Nama::MidiBus;
use v5.36; use Carp; our @ISA = 'Audio::Nama::Bus';
our $VERSION = 1.0;
use Audio::Nama::Log qw(logsub logpkg);
use Audio::Nama::Util qw(input_node);
use Audio::Nama::Globals qw(:trackrw);
sub apply {
my ($bus) = @_;
logpkg(__FILE__,__LINE__,'debug', "bus ". $bus->name. ": applying routes");
logpkg(__FILE__,__LINE__,'debug', "Bus destination is type: $bus->{send_type}, id: $bus->{send_id}");
#
}
sub remove { } # We never remove the Midi bus
}
# ---------- Bus routines --------
{
package Audio::Nama;
use v5.36; use Carp;
use Audio::Nama::Util qw(dest_type);
our (
$this_track,
$this_bus,
%tn,
%bn,
);
sub set_current_bus {
my $track = shift || ($this_track ||= $tn{Main});
return unless $track; # needed for test environment
# The current sequence changes when the user touches a
# track that belongs to another sequence.
$this_sequence = $bn{$track->group} if (ref $bn{$track->group}) =~ /Sequence/;
my $bus_name =
$track->name =~ /Main|Mixdown/
? 'Main'
lib/Audio/Nama/Bus.pm view on Meta::CPAN
}
sub select_bus {
my $name = shift;
my $bus = $bn{$name} or return;
$this_bus = $name;
$this_bus_o = $bus;
}
sub add_bus {
# creates named bus if necessary
# creates named mix track if necessary
# sets mix track to MON with bus as source
my ($name, @args) = @_;
# don't create bus if such named already exists
Audio::Nama::SubBus->new(
name => $name,
send_type => 'track',
send_id => $name,
) unless $bn{$name};
my $bus = $bn{$name};
# modify bus and track settings to activate bus
$bus->set(rw => MON);
@args = (
rw => MON,
source_type => 'bus',
source_id => $name,
@args
);
$tn{$name} and pager_newline( qq($name: setting as mix track for bus "$name"));
my $track = $tn{$name}// add_track($name, width => 2);
$track->set( @args );
}
sub add_submix {
my ($name, $dest_id, $bus_type) = @_;
my $dest_type = dest_type( $dest_id );
# dest_type: soundcard | jack_client | loop | jack_port | jack_multi
logpkg(__FILE__,__LINE__,'debug',"name: $name, dest_type: $dest_type, dest_id: $dest_id");
if ($bn{$name} and (ref $bn{$name}) !~ /SendBus/){
Audio::Nama::throw($name,": bus name already in use. Aborting."), return;
}
if ($bn{$name}){
Audio::Nama::pager_newline( qq(monitor bus "$name" already exists. Updating with new tracks.) );
} else {
my @args = (
name => $name,
send_type => $dest_type,
send_id => $dest_id,
);
my $class = $bus_type eq 'cooked' ? 'Audio::Nama::SendBusCooked' : 'Audio::Nama::SendBusRaw';
my $bus = $class->new( @args );
$bus or carp("can't create bus!\n"), return;
}
map{ Audio::Nama::EarTrack->new( name => "$name\_$_", # BusName_TrackName
rw => MON,
target => $_,
group => $name,
width => 2,
hide => 1,
)
} $bn{Main}->tracks;
}
sub update_submix {
my $name = shift;
add_submix( $name,
$bn{$name}->send_id),
"dummy",
}
sub remove_submix_helper_tracks {
my $name = shift;
#say "got name: $name";
my @submixes = submixes();
#say "got submixes:", Dumper \@submixes;
for my $sm ( @submixes ){
my $to_remove = join '_', $sm->name, $name;
#say "to_remove: $to_remove";
local $quiet;
$quiet++;
for my $name ($sm->tracks) {
$tn{$name}->remove, last if $name eq $to_remove
}
}
}
sub submixes { grep { (ref $_) =~ /SendBusCooked/ } values %Audio::Nama::Bus::by_name }
}
}
1;
__END__
( run in 0.732 second using v1.01-cache-2.11-cpan-39bf76dae61 )