-
-
Notifications
You must be signed in to change notification settings - Fork 53
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
CLI not working on Windows? #63
Comments
Hello! Thanks for taking the time to raise it. This looks like a windows specific error. I'll try to replicate and let you know |
Could please omit the -t option and just run |
Thanks for the reply I just tried it without -t but unfortunately the same error occurs Results
Something else that I'm not sure if it could be related or not but wanted to mention. I'm unable to execute go2tv directly from cmd or Powershell and get any output. In order to see any output, I have to use the following syntax (here in Powershell) go2tv -v c:\TheHobbit.mp4 | out-string If I dont add the Alternatively this also works in powershell to get output written to a file (though doesn't output to console) Start-process 'go2tv.exe' -ArgumentList '-v c:\TheHobbit.mp4' -RedirectStandardOutput "c:\logs\go2tv_standard.log" -RedirectStandardError "c:\logs\go2tv_error.log" Here is another example using .NET directly in PS. This will output standard and errors to console. So it appears to only work if using output redirection. I dont know anything about go so not sure if any of this information is helpful but sharing it all the same $process = [System.Diagnostics.Process]::new()
$process.StartInfo.FileName = 'go2tv.exe'
$process.StartInfo.Arguments = '-v c:\TheHobbit.mp4'
$process.StartInfo.UseShellExecute = $false
$process.StartInfo.RedirectStandardOutput = $true
$process.StartInfo.RedirectStandardError = $true
$process.Start()
[console]::WriteLine($process.StandardOutput.ReadToEnd())
[console]::WriteLine($process.StandardError.ReadToEnd())
$process.WaitForExit() Unfortunately any of these methods results in the same original error. I just had to get a bit creative to finally get any output to know what was going on |
I have the feeling that the reason you can't get any media playback is the fact that there is no attached console to the application. When I first built the application for Windows, there was a command prompt appearing when I double clicked the app. The solution to that was to use the "windowsgui" flag during compilation. I didn't realize that this flag would cause issues with ability to pass arguments from cmd. I’m a Linux user myself and nobody raised it until now. I compiled the latest stable version without this flag just to confirm if this is what is causing the "The handle is invalid" error. Could you please test it and let me know if that fixes it? |
Ah ok that makes sense. I had wondered if there were little to few Windows users. Honesty, for my needs I don't really need any gui at all since I want to incorporate it into automation script/app. So if I can use it 100% command-line, that is perfect for me! I just tested the upload you provided and I'm happy to say it now works as expected! I tested quickly with I was also able to still use the GUI without any issue as well I'll do some more extensive testing in a day or so (such as casting URLs and trying transcoding with -tc..etc) but otherwise this version looks like it will solve my issue. Can't thank you enough! |
No worries, glad this fixed the issue. I also have https://github.com/alexballas/go2tv/tree/main/cmd/go2tv-lite which is an ever lighter version. No gui and no ability to use hot keys in the CLI. Just raw streaming. Also pasting it here in case you want to use that instead. |
Oh wow, now I feel kind of silly for not seeing that! That is actually exactly what I was looking for! Thank you! One last question and this is a bit off topic but, is there a way to transcode with ffmpeg and pass parameters to it through go2tv when casting from URLs? Such as if I want to change the encoding format or other parameters?. I'm doing some streaming through libvlc and I'm having a lot of trouble with its transcoding while also streaming via HTTP. If I can bypass transcoding at all with libvlc and instead do so while casting through go2tv, that would simplify my life significantly! |
Transcoding in Go2TV with URLs works by passing the http stream through pipes to the ffmpeg command as seen here https://github.com/alexballas/go2tv/blob/main/utils/transcode_windows.go#L24-L45. It's all hard coded as the goal of the app is to provide an easy way for everyone to stream stuff. If you have some specific ffmpeg parametres in mind you can change the code in that part and recompile. |
Ah ok understood and makes sense. I haven't ever compiled with go before so it will be a good learning exercise at least. Thanks again! |
Nothing further to do in this issue. Resolving. |
Thank you so much for including an updated build! |
Starting with release 1.18.0, the CLI will work smoothly on Windows by default. A brief black prompt will appear during app initialization, but it won’t impact the experience. |
Hello,
First, excellent work on this utility. its exactly what I want, simple and lightweight. I'm baffled how hard it has been to find something that's not some huge Media Server/SDK for simple casting.
Anyway, I cant seem to get go2tv to work at all in command line mode on Windows 10. GUI mode works just fine.
I'm able to find my device fine using
go2tv.exe -l
Results
Then I've tried running this from command line
go2tv.exe -t http://192.168.50.231:1839 -v c:\TheHobbit.mp4
I get this error
I've tried using a Media URL instead of a local file, get the same error.
If I use the GUI and select the same file and select the device which shows under Select Device, and hit Play, it works great
I'm wondering if I'm just missing some simple syntax. I've also tried adding -tc and made sure ffmpeg is installed but no difference.
I've tried 2 machines on my network (both Windows 10) with the same result. Any ideas?
Thanks!
The text was updated successfully, but these errors were encountered: