1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222
|
# Frequently Asked Questions
## What does this message means?
### Type error
Liquidsoap might also reject a script with a series of errors of the form ` this value has type ... but it should be a subtype of ...`
. Usually the last error tells you what the problem is, but the previous errors might provide a better information as to where the error comes from.
For example, the error might indicate that a value of type `int` has been passed where a float was expected, in which case you should use a conversion, or more likely change an integer value such as `13` into a float `13.`.
A type error can also show that you're trying to use a source of a certain content type (e.g., audio) in a place where another content type (e.g., pure video) is required. In that case the last error in the list is not the most useful one, but you will read something like this above:
```
At ...:
Error 5: this value has type
source(video=canvas(_),...)
but it should be a subtype of
source(audio=pcm(_),...)
```
Sometimes, the type error actually indicates a mistake in the order or labels of arguments. For example, given `output.icecast(mount="foo.ogg",source)` liquidsoap will complain that the second argument is a source (`source(?A)`) but should be a format (`format(?A)`): indeed, the first unlabelled argument is expected to be the encoding format, e.g., `%vorbis`, and the source comes only second.
Finally, a type error can indicate that you have forgotten to pass a mandatory parameter to some function. For example, on the code `fallback([source.mux.audio(x),...])`, liquidsoap will complain as follows:
```
At line ...:
Error 5: this value has type
[(?id : _, audio : _) -> _]
but it should be a subtype of the type of the value at ../libs/switches.liq, line 11, char 11-18
[source(_)] (inferred at ../libs/list.liq, line 102, char 29)
```
Indeed, `fallback` expects a source, but `source.mux.audio(x)` is still a function expecting the `audio` parameter.
### That source is fallible!
See the [quickstart](quick_start.html), or read more about
[sources](sources.html).
### Clock error
Read about [clocks](clocks.html) for the errors
`a source cannot belong to two clocks`
and
`cannot unify two nested clocks`.
### We must catchup x.xx!
This error means that a clock is getting late in liquidsoap. This can
be caused by an overloaded CPU, if your script is doing too much encoding
or processing: in that case, you should reduce the load on your machine
or simplify your liquidsoap script. The latency may also be caused by
some lag, for example a network lag will cause the icecast output to
hang, making the clock late.
The first kind of latency is problematic because it tends to accumulate,
eventually leading to the restarting of outputs:
```
Too much latency!
Resetting active source...
```
The second kind of latency can often be ignored: if you are streaming to
an icecast server, there are several buffers between you and your
listeners which make this problem invisible to them. But in more realtime
applications, even small lags will result in glitches.
In some situations, it is possible to isolate some parts of a script
from the latency caused by other parts. For example, it is possible to
produce a clean script and back it up into a file, independently of
its output to icecast (which again is sensitive to network lags).
For more details on those techniques, read about [clocks](clocks.html).
### Unable to decode ``file'' as {audio=pcm}!
This log message informs you that liquidsoap failed to decode a file, not
necessarily because it cannot handle the file, but also possibly because
the file does not contain the expected media type. For example, if audio and video
is expected, an audio file with no video will be rejected.
Liquidsoap is also able to convert audio channels in most situations. Typically,
if stereo data is expected but the file contains mono audio, liquidsoap will use
the single audio channel as both left and right channels.
### Runtime exceptions
Liquidsoap scripts can raise runtime errors of the form:
```
At line 3, char 45:
Error 14: Uncaught runtime error:
type: not_found, message: "File not found!"
```
These are errors that the script programmer can catch and decide what to do when they
occur. Such errors will typically occur when trying to read a file that does not
exist and etc.
The [language page](language.html) has more details about errors, how to raise them
and how to catch them. You can head over there to get more information.
### Crashes
Liquidsoap dies with messages such as these by the end of the log:
```
... [threads:1] Thread "XXX" aborts with exception YYY!
... [stderr:3] Thread 2 killed on uncaught exception YYY.
... [stderr:3] Raised at file ..., line ..., etc.
```
Those internal errors can be of two sorts:
- **Bug**: Normally, this means that you've found a bug, which you should report on the mailing list or bug tracker.
- **User error**: In some cases, we let an exception go on user errors, instead of nicely reporting and handling it. By looking at the surrounding log messages, you might realize that liquidsoap crashed for a good reason, that you are responsible for fixing. You can still report a bug: you should not have seen an exception and its backtrace.
In any case, once that kind of error happens, there is no way for the
user to prevent liquidsoap from crashing. Those exceptions cannot be
caught or handled in any way at the level of liquidsoap scripts.
## Troubleshooting
### Pulseaudio
When using ALSA input or output or, more generally any audio input or output
that is not using pulseaudio, you should disable pulseaudio, which is often installed
by default. Pulseaudio emulates ALSA but this also generates bugs,
in particular errors of this form:
```
Alsa.Unknown_error(1073697252)!
```
There are two things you may do:
- Make sure your alsa input/output does not use pulseaudio
- Disable pulseaudio on your system
In the first case, you should first find out which sound card you want to use,
with the command `aplay -l`. An example of its output is:
```
**** List of PLAYBACK Hardware Devices ****
card 0: Intel [HDA Intel], device 0: STAC92xx Analog [STAC92xx Analog]
Subdevices: 1/1
Subdevice #0: subdevice #0
```
In this case, the card we want to use is: device `0`, subdevice `0`, thus:
`hw:0,0`. We now create a file `/etc/asound.conf` (or `~/.asoundrc` for single-user
configuration) that contains the following:
```liquidsoap
pcm.liquidsoap {
type plug
slave { pcm "hw:0,0" }
}
```
This creates a new alsa device that you can use with liquidsoap. The `plug` operator
in ALSA is used to work-around any hardware limitations in your device (mixing multiple
outputs, resampling etc.). In some cases you may need to read more about ALSA and define
your own PCM device.
Once you have created this device, you can use it in liquidsoap as follows:
```liquidsoap
input.alsa(device="pcm.liquidsoap", ...)
```
In the second case -- disabling pulseaudio, you can edit the file `/etc/pulse/client.conf` and
change or add this line:
```
autospawn = no
```
And kill any running pulseaudio process:
```
killall pulseaudio
```
Otherwise you may simply remove pulseaudio's packages, if you use Debian or Ubuntu:
```
apt-get remove pulseaudio libasound2-plugins
```
### Listeners are disconnected at the end of every track
Several media players, including renowned ones, do not properly support
Ogg/Vorbis streams: they treat the end of a track as an end of file,
resulting in the disconnection.
Players that are affected by this problem include VLC.
Players that are not affected include ogg123, liquidsoap.
One way to work around this problem is to not use Ogg/Vorbis (which we
do not recommend) or to not produce tracks within a Vorbis stream.
This is done by dropping both metadata and track marks (for example
using `source.drop.metadata_track_marks`).
### Encoding blank
Encoding pure silence is often too effective for streaming: data is so
compressed that there is nothing to send to listeners, whose clients
eventually disconnect. Therefore, it is a good idea to use a non-silent
jingle instead of `blank()` to fill in the blank. You can
also achieve various effects using synthesis sources such as
`noise()`, `sine()`, etc.
### Temporary files
Liquidsoap relies on OCaml's `Filename.tmp_dir_name` variable to store temporary
files. It is documented as follows:
The name of the temporary directory: Under Unix, the value of the `TMPDIR` environment
variable, or `"/tmp"` if the variable is not set. Under Windows, the value of the `TEMP`
environment variable, or `"."` if the variable is not set.
|