Una vez que ya te han comentado cosas sobre los DEFINE, yo te diría que este problema, aunque se soluciona tal y come te han comentado, creo que denota que estás realizando un mal diseño.
Que una determinada unidad, necesite del FormMain para ejecutar un método (y más una unidad que vas a compartir entre varios proyectos) te está indicando que seguramente algo no es correcto (aunque sea "solucionable" tal y como te han dicho).
Si se puede, ese procedimiento al que estás llamado debería estar fuera en una unit aparte, para poder llamarlo con parámetros cuando fuera necesario.
"Imagina que tienes un TEdit(edit1) en un formulario (form1), y al realizar un cambio en el Edit1, necesitamos ocultar otro componente (Edti2) del form1".
Lo que no hacemos en el TEdit es colocar un DEFINE que diga (aunque funcinaría):
Código Delphi
[-]
{$IFDEF FORM1}
...
form1.Edit2.Visible := False;
...
{$ENDIF}
¿Cómo lo solventamos? Se añade al TEdit un evento OnChange, que captura el formulario que lo necesite.
Creo que en este caso (por lo poco que comentas) una solución un poco más correcta sería una similar.
Define en el segundo form un evento y lánzalo en lugar de la llamada:
Código Delphi
[-]
type
...
private
...
property OnEvento1:TNotifyEvent read FOnEvento1 write FOnEvento1;
...
end;
Procedure TForm.acViewAccountExecute(Sender: TObject);
Begin
Inherited;
{$IFNDEF NOTMAIN}
If Not dsOutboundList.DataSet.IsEmpty then
Begin
if Assigned(OnEvento1) then begin
OnEvento1(Self);
end;
pRefresh;
End;
{$ENDIF}
End;
Desde el Main si es necesario, deberás asignar ese evento para capturarlo.