Normally, a grammar should produce an automaton where at each state the parser has only one action to do (see Wisent Parsing).
In certain cases, a grammar can produce an automaton where, at some states, there are more than one action possible. Such a grammar is ambiguous, and generates conflicts.
The parser can't be driven by an automaton which isn't completely deterministic, that is which contains conflicts. It is necessary to resolve the conflicts to eliminate them. Wisent resolves conflicts like Bison does.
There are two sorts of conflicts:
Such conflicts are resolved by choosing to shift, unless otherwise directed by operator precedence declarations. See Shift/Reduce, in the Bison manual for more information.
Such conflicts are resolved by choosing to use the rule that appears first in the grammar, but it is very risky to rely on this. Every reduce/reduce conflict must be studied and usually eliminated. See Reduce/Reduce, in the Bison manual for more information.