Commit 6912d838 authored by Felix Paul Kühne's avatar Felix Paul Kühne

macosx/CAS: implement streaming

minor announcement stuff left to do
parent c52ba916
...@@ -274,6 +274,8 @@ static VLCConvertAndSave *_o_sharedInstance = nil; ...@@ -274,6 +274,8 @@ static VLCConvertAndSave *_o_sharedInstance = nil;
- (IBAction)finalizePanel:(id)sender - (IBAction)finalizePanel:(id)sender
{ {
// HTTP, TODO: mux checking, since only MPEG PS, MPEG TS, MPEG 1, OGG, RAW and ASF are allowed
playlist_t * p_playlist = pl_Get(VLCIntf); playlist_t * p_playlist = pl_Get(VLCIntf);
input_item_t *p_input = input_item_New([_MRL UTF8String], [[_dropin_media_lbl stringValue] UTF8String]); input_item_t *p_input = input_item_New([_MRL UTF8String], [[_dropin_media_lbl stringValue] UTF8String]);
...@@ -281,6 +283,8 @@ static VLCConvertAndSave *_o_sharedInstance = nil; ...@@ -281,6 +283,8 @@ static VLCConvertAndSave *_o_sharedInstance = nil;
return; return;
input_item_AddOption(p_input, [[self composedOptions] UTF8String], VLC_INPUT_OPTION_TRUSTED); input_item_AddOption(p_input, [[self composedOptions] UTF8String], VLC_INPUT_OPTION_TRUSTED);
if (b_streaming)
input_item_AddOption(p_input, [[NSString stringWithFormat:@"ttl=%@", [_stream_ttl_fld stringValue]] UTF8String], VLC_INPUT_OPTION_TRUSTED);
int returnValue; int returnValue;
returnValue = playlist_AddInput(p_playlist, p_input, PLAYLIST_STOP, PLAYLIST_END, true, pl_Unlocked); returnValue = playlist_AddInput(p_playlist, p_input, PLAYLIST_STOP, PLAYLIST_END, true, pl_Unlocked);
...@@ -463,14 +467,6 @@ static VLCConvertAndSave *_o_sharedInstance = nil; ...@@ -463,14 +467,6 @@ static VLCConvertAndSave *_o_sharedInstance = nil;
return; return;
} }
NSString *tmpString = [_stream_address_fld stringValue];
if ([[tmpString componentsSeparatedByString:@":"] count] != 5 || [[tmpString componentsSeparatedByString:@"."] count] != 3 || ![tmpString isEqualToString:@"localhost"]) {
NSBeginInformationalAlertSheet(_NS("Invalid Output Destination"),
_NS("OK"), @"", @"", _stream_panel, nil, nil, nil, nil,
@"%@", _NS("The entered output destination IP does not appear to be legit."));
return;
}
/* store destination for further reference and update UI */ /* store destination for further reference and update UI */
[self setOutputDestination: [_stream_address_fld stringValue]]; [self setOutputDestination: [_stream_address_fld stringValue]];
[self updateOKButton]; [self updateOKButton];
...@@ -872,11 +868,32 @@ static VLCConvertAndSave *_o_sharedInstance = nil; ...@@ -872,11 +868,32 @@ static VLCConvertAndSave *_o_sharedInstance = nil;
[composedOptions appendFormat:@",soverlay"]; [composedOptions appendFormat:@",soverlay"];
} }
// add muxer
[composedOptions appendFormat:@"}:standard{mux=%@", [self.currentProfile objectAtIndex:0]];
// add output destination (file only at this point) if (!b_streaming) {
[composedOptions appendFormat:@",dst=%@,access=file}", _outputDestination]; /* file transcoding */
// add muxer
[composedOptions appendFormat:@"}:standard{mux=%@", [self.currentProfile objectAtIndex:0]];
// add output destination
[composedOptions appendFormat:@",dst=%@,access=file}", _outputDestination];
} else {
/* streaming */
if ([[[_stream_type_pop selectedItem] title] isEqualToString:@"RTP"])
[composedOptions appendFormat:@":rtp{mux=ts,dst=%@,port=%@", _outputDestination, [_stream_port_fld stringValue]];
else if ([[[_stream_type_pop selectedItem] title] isEqualToString:@"UDP"])
[composedOptions appendFormat:@":standard{mux=ts,dst=%@,port=%@,access=udp", _outputDestination, [_stream_port_fld stringValue]];
else if ([[[_stream_type_pop selectedItem] title] isEqualToString:@"MMSH"])
[composedOptions appendFormat:@":standard{mux=asfh,dst=%@,port=%@,access=mmsh", _outputDestination, [_stream_port_fld stringValue]];
else
[composedOptions appendFormat:@":standard{mux=%@,dst=%@,port=%@,access=http", [self.currentProfile objectAtIndex:0], [_stream_port_fld stringValue], _outputDestination];
if ([_stream_sap_ckb state])
[composedOptions appendFormat:@",sap,name=\"%@\"", [_stream_channel_fld stringValue]];
if ([_stream_sdp_ckb state])
[composedOptions appendFormat:@",sdp=%@", [_stream_sdp_fld stringValue]];
[composedOptions appendString:@"} :sout-keep"];
}
NSString * returnString = [NSString stringWithString:composedOptions]; NSString * returnString = [NSString stringWithString:composedOptions];
[composedOptions release]; [composedOptions release];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment