/// <summary>
        /// Programm zu auslesen er Datensätze aus dem Datsfox Terminal
        /// </summary>
        /// <param name="Optionen">Übertragungsoptionen zum Datafox Terminal</param>
        /// <returns>Ausgelesene Datensätze aus dem Terminal</returns>
        public static List <string> ListeAusTerminalAuslesen(OptionenTerminal Optionen)
        {
            string msg;

            byte[] buf = new byte[256];
            int    length, errorID = 0, result;
            var    listeAntwort = new List <string>();
            var    errorString  = new StringBuilder(255);

            try
            {
                // Schleife nur um mit break abzubrechen, kein goto verwenden.
                do
                {
                    // Lesen der Datensatzbeschreibungen, diese stellen die Tabellendefinitionen dar.
                    DFComDLL.TableDeclarations records = new DFComDLL.TableDeclarations(DFComDLL.TableDeclarations.TableType.Record, "Records.xml");
                    if (records.LoadFromDevice(Optionen.ChannelId, Optionen.DeviceId, "") == false)
                    {
                        // Fehlertext ermitteln
                        DFComDLL.DFCGetErrorText(Optionen.ChannelId, errorID, 0, errorString, errorString.Capacity);
                        msg = $"Lesen der Datensatzbeschreibung ist fehlgeschlagen.\nFehlerbeschreibung: {errorString}";
                        throw new MyException(msg);
                    }

                    if (records.Tables == null)
                    {
                        // Es liegen keine Datensatzbeschreibungen vor.
                        msg = string.Format("Es liegen keine Datensatzbeschreibungen vor.\nBitte prüfen Sie das eingespielte Setup.}");
                        throw new MyException(msg);
                    }

                    do
                    {
                        length = buf.Length;
                        // Datensatz lesen
                        if ((result = DFComDLL.DFCReadRecord(Optionen.ChannelId, Optionen.DeviceId, buf, out length, out errorID)) < 0)
                        {
                            msg = string.Format("Datensatz konnte nicht aus Terminal gelesen werden. Fehlercode: {0}", errorID);
                            throw new MyException(msg);
                        }

                        if (result == 0)
                        {
                            msg = "Es sind keine Anmeldungen im Terminal regiestriert.";
                            Logger.Write(msg, "Service", 0, 0, TraceEventType.Verbose);
                            break;
                        }

                        DFComDLL.DFRecord rs = new DFComDLL.DFRecord(buf, records);
                        listeAntwort.Add(rs.TabbedString());

                        // Datensatz quittieren
                        if (DFComDLL.DFCQuitRecord(Optionen.ChannelId, Optionen.DeviceId, out errorID) < 0)
                        {
                            msg = string.Format("Datensatz konnte nicht im Terminal quittiert werden. Fehlercode: {0}", errorID);
                            throw new MyException(msg);
                        }
                    } while (true);
                } while (false);
            }
            catch (Exception f)
            {
                msg = "Fehler beim einlesen der Anmeldedaten aus dem Terminal";
                throw new Exception(msg, f);
            }

            return(listeAntwort);
        }
        public static void ListenInTerminalSchreiben(OptionenTerminal Optionen, string PfadUpdateBediener)
        {
            string msg;
            var    errorString = new StringBuilder(255);
            int    errorID = 0;
            int    idx, res = 0;
            int    importCount = 0;
            var    import      = new DFComDLL.ListImport();

            try
            {
                // Listenformate aus Terminal auslesen
                var lists = new DFComDLL.TableDeclarations(DFComDLL.TableDeclarations.TableType.List, "Lists.xml");
                if (lists.LoadFromDevice(Optionen.ChannelId, Optionen.DeviceId, "") == false)
                {
                    // Fehlertext ermitteln
                    DFComDLL.DFCGetErrorText(Optionen.ChannelId, errorID, 0, errorString, errorString.Capacity);
                    msg = $"Lesen der Listenbeschreibung ist fehlgeschlagen.\nFehlerbeschreibung: {errorString}";
                    Logger.Write(msg, "Service", 0, 0, TraceEventType.Warning);
                }

                if (lists.Tables == null)
                {
                    msg = $"Es liegen keine Listendefinitionen im Verzeichnis {PfadUpdateBediener} vor.";
                    Logger.Write(msg, "Service", 0, 0, TraceEventType.Warning);
                    return;
                }

                DFComDLL.DFCClrListenBuffer(Optionen.ChannelId);

                // Vorliegende Listendaten importieren und übertragen.
                for (idx = 0; idx < lists.Tables.Length; idx++)
                {
                    string fileName = string.Format("{0}*.txt", lists.Tables[idx].Name);
                    var    files    = Directory.GetFiles(PfadUpdateBediener, fileName);

                    if (files.Length == 0 || files[0].EndsWith("txt") == false)
                    {
                        break;
                    }

                    if (files.Length > 1)
                    {
                        msg = $"Für Liste [{lists.Tables[idx].Name}] liegen mehrere Listendateien vor.";
                        Logger.Write(msg, "Service", 0, 0, TraceEventType.Warning);
                    }

                    try
                    {
                        // Importieren der Listendaten
                        import.Import(lists.Tables[idx], files[0]);
                        res = DFComDLL.DFCMakeListe(Optionen.ChannelId, idx, import.RecordCount, import.Size, import.Mem, 0);

                        if (res == 0)
                        {
                            msg = $"Übergabe der Listendaten aus der Datei [{files[0]}] ist fehlgeschlagen.";
                            Logger.Write(msg, "Service", 0, 0, TraceEventType.Warning);
                            continue;
                        }

                        msg = $"Liste [{lists.Tables[idx].Name} (Datensätze: {lists.Tables[idx].Name})] wurde importiert. Datei: {files[0]}";
                        Logger.Write(msg, "Service", 0, 0, TraceEventType.Verbose);
                    }
                    catch (DFComDLL.ListImportException ex)
                    {
                        msg = $"Import von Liste [{lists.Tables[idx].Name}] schlug fehl. Datei: {files[0]}\nGrund: {ex.Message}";
                        Logger.Write(msg, "Service", 0, 0, TraceEventType.Warning);
                        continue;
                    }

                    importCount++;
                }

                if (importCount == 0)
                {
                    msg = "Es liegen keine Listendaten vor.";
                    Logger.Write(msg, "Service", 0, 0, TraceEventType.Verbose);
                    return;
                }

                res = DFComDLL.DFCLoadListen(Optionen.ChannelId, Optionen.DeviceId, out errorID);
                if (res == 0)
                {
                    // Fehlertext ermitteln
                    DFComDLL.DFCGetErrorText(Optionen.ChannelId, errorID, 0, errorString, errorString.Capacity);
                    msg = $"Übertragung der Listendaten ist fehlgeschlagen.\nGrund: {errorString}";
                    Logger.Write(msg, "Service", 0, 0, TraceEventType.Warning);
                }

                msg = string.Format("Es wurde{0} {1} von {2} Listen übertragen.", (importCount == 1) ? "" : "n", importCount, lists.Tables.Length);
                Logger.Write(msg, "Service", 0, 0, TraceEventType.Information);
            }
            catch (Exception f)
            {
                msg = $"Fehler beim eintragen von Daten in das Terminal !\nGrund: {f.Message}";
                Logger.Write(msg, "Service", 0, 0, TraceEventType.Warning);
            }
        }