By default gschem saves external symbol references, which means it saves the basename of the symbol ("res.sym" in our example) in the sheet file. Then upon load gschem goes and looks up the first matching file from the current library.
This is said to be good because if you fix a symbol in your library, it automatically affects all old sheets that uses that symbol whenever you are going to load those sheets.
Trivial risks/drawbacks are:
There are two ways to avoid all the above:
Unfortunately method b) is not as safe as we like to believe, and this is related to (the missing) "project file concept" that gafrc sort of tries to work around.
Unpack the tarball and cd to its geda_symref_bug, then run:
gschem p1/A.sch p2/B.sch
This will load two schematics, each with a different resistor symbol shorted. The symbols are loaded from the corresponding local libraries, p1/sym1/ and p2/sym2/.
In the library window both sym1 and sym2 are accessible. Place the other style res symbol on each page, so both pages have both kind of symbols. Then save all, quit and load both pages again the same way:
gschem p1/A.sch p2/B.sch
Suddenly the newly placed resistor is of the wrong symbol on both pages!
So what worked in the initial edit silently breaks after a reload.
This is because the external symbol file reference works in two different ways:
This means sheet files intended to be reused in multiple designs as a building block shouldn't rely on local symbol libraries and gafrc, because when the sheet is then used in a random "project", and edited, it may accidentally get symbols that look good at placement but will silently fail when reloading even the same "project".
(Since there's no real project file in gEDA, "project" in this context means loading multiple sheets in the GUI editor or passing the same sheets together to the netlister.)