Dies ist die alte 4D Dokumentations-Website. Die neue und aktualisierte Dokumentation finden Sie unter developer.4d.com |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
4D v20
Überholte und entfernte Funktionalitäten
|
Funktion | Ersetzung | Status in der aktuellen 4D Version |
PDFCreator-Treiber | Nativer Windows PDF-Treiber | Veraltet |
Verstoß gegen die Objektnotation | Überprüfen Sie die Übereinstimmung und aktivieren Sie die Option Kompatibilität der Objektnotation verwenden | Entfernt |
Interprozess-Variablen | Shared Objects und Collections, Storage | Veraltet |
4D ODBC Pro | Eingebautes ODBC/SQL Pass through oder 4D REST API | Entfernt |
4D für OCI unter macOS | Eingebautes ODBC/SQL Pass through oder 4D REST API | Entfernt |
4D ODBC Driver unter macOS | 4D REST API | Entfernt |
4D Internet Commands - Mail | Transporter (IMAP, SMTP, POP3), Email-Objekte | Überholt |
4D Internet Commands - File Transfert | System workers | Überholt |
Benutzerformulare | Dynamische Formulare | Überholt |
Dynamische Zuweisung von Variablen, die über HTTP empfangen werden (Kompatibilitätsoption für Datenbanken, die vor v13.4 erstellt wurden) | WEB GET VARIABLES Befehl (um Variablen wiederherzustellen). WEB GET BODY PART/WEB Get body part count Befehle (um gepostete Dateien wiederherzustellen) | Veraltet |
Konvertierte | N->1 Tabellen verwenden | Veraltet |
Datei und Ordner APIs auf Mac | Path to object, Object to path | Veraltet |
Code-basierte Standardaktionen | String-Muster ("ak"-Konstanten im Standardaktion Thema) | Veraltet |
Mac Ressourcen | Verwenden Sie den Ordner "Ressourcen". Aus Kompatibilitätsgründen können Sie ihn in konvertierten Datenbanken weiterhin verwenden. Wir unterstützen keine Schreibzugriffsbefehle mehr. | OS (cicn-Symbole: entfernt.) Datenbank-.RSR-Dateien werden nicht automatisch geöffnet. Sie müssen Open resource file verwenden. |
CPU Priorität verwalten | keine | Überholt |
Legacy-Netzwerkschicht | ServerNet verwenden | Veraltet |
4D Mobile | ORDA und REST Server | Veraltet |
Erläuterung der Werte für die Spalte "Status":
Jeder überholte Befehl erhält die Vorsilbe _o_ und ist in 4D Listen (Code-Editor, type-ahead Funktion, etc.) nicht verfügbar. Überholte (oder veraltete) Befehle werden nicht aus vorhandenem Code entfernt und funktionieren wie gewohnt, solange sie noch unterstützt werden. Sie lassen sich weiterhin (auch wenn wir davon abraten) mit der Vorsilbe _o_ im Namen in einer Methode hinzufügen und werden korrekt interpretiert.
Befehl | Ersetzt durch | Überholt seit | |
Kapitel 4D Umgebung: | |||
_o_DATA SEGMENT LIST | - | v11 | |
Kapitel Auswahl: | |||
_o_MOBILE Return selection | ORDA | v18 | |
Kapitel Backup: | |||
_o_INTEGRATE LOG FILE | INTEGRATE MIRROR LOG FILE | v16 | |
Kapitel Benutzerformulare: | |||
_o_CREATE USER FORM | Dynamische Formulare | v17 R4 | |
_o_DELETE USER FORM | Dynamische Formulare | v17 R4 | |
_o_EDIT FORM | Dynamische Formulare | v17 R4 | |
_o_LIST USER FORMS | Dynamische Formulare | v17 R4 | |
Kapitel Bilder: | |||
_o_PICTURE TO GIF | PICTURE TO BLOB | v16 R5 | |
Kapitel Compiler: | |||
_o_ARRAY STRING | ARRAY TEXT | v12 | |
_o_C_GRAPH | (SVG mit dem Befehl GRAPH verwenden) | v12 | |
_o_C_INTEGER | C_LONGINT | v12 | |
_o_C_STRING | C_TEXT (sobald die Datenbank in Unicode ist) | v12 | |
Kapitel Dateneingabe: | |||
_o_ADD SUBRECORD | ADD RECORD in der n Tabelle einer N->1 Verknüpfung | v12 | |
_o_MODIFY SUBRECORD | MODIFY RECORD in der n Tabelle einer N->1 Verknüpfung | v12 | |
Kapitel Diagramme: | |||
GRAPH (4D Diagrammbereich verwenden) | stattdessen ein SVG Bild verwenden | v12 | |
Kapitel Drag and Drop: | |||
_o_DRAG AND DROP PROPERTIES | Befehle aus dem Kapitel Pasteboard | v17 R4 | |
Kapitel Drucken: | |||
_o_PAGE SETUP | SET PRINT OPTION, GET PRINT OPTION, Print settings to BLOB, BLOB to print settings | v18 | |
Kapitel Formulare: | |||
_o_FORM GET PARAMETER | Deaktiviert | v17 R4 | |
Kapitel Formularereignisse: | |||
_o_During | Ersetzen mit Form event code und geeignetem Ereignis | v12 | |
Kapitel Hierarchische Listen: | |||
_o_REDRAW LIST | im Code entfernen (führt seit v11 nichts mehr aus) | v11 | |
Kapitel Listboxen: | |||
LISTBOX Get property Konstanten: | |||
_o_lk display hor scrollbar/_o_lk display ver scrollbar | OBJECT GET SCROLLBAR | v16 R3 | |
_o_lk footer height | LISTBOX Get footers height | v16 R3 | |
_o_lk header height | LISTBOX Get headers height | v16 R3 | |
_o_lk hor scrollbar position/_o_lk ver scrollbar position | OBJECT GET SCROLL POSITION | v16 R3 | |
Kapitel Objekte (Formulare): | |||
_o_OBJECT Get action | OBJECT Get action | v16 R3 | |
_o_OBJECT SET COLOR | OBJECT SET RGB COLORS | v18 | |
Kapitel SQL: | |||
_o_USE EXTERNAL DATABASE | SQL LOGIN | v12 | |
_o_USE INTERNAL DATABASE | SQL LOGOUT | v12 | |
Kapitel String: | |||
_o_Mac to Win | v11 | ||
_o_Win to Mac | v11 | ||
Kapitel Systemdokumente: | |||
_o_Document type | Path to object | v12 | |
_o_Document creator | Path to object | v16 R6 | |
_o_SET DOCUMENT TYPE | Object to path | v16 R6 | |
_o_SET DOCUMENT CREATOR | Object to path | v16 R6 | |
_o_MAP FILE TYPES | UTIs und Info.plist verwenden | v16 R6 | |
Kapitel Systemumgebung: | |||
_o_Font name | Identifier für Schrift verwenden | v14 | |
OBJECT SET FONT akzeptiert für Schrift keinen Parameter Lange Ganzzahl: Dieser Parameter ist jetzt ein String und Sie müssen den Schriftnamen angeben. | |||
_o_Gestalt | Get system info / Is macOS / Is Windows | v17 | |
_o_PLATFORM PROPERTIES | Get system info / Is macOS / Is Windows | v17 | |
User Forms Thema: | |||
_o_CREATE USER FORM | Dynamische Formulare | v17 R4 | |
_o_DELETE USER FORM | Dynamische Formulare | v17 R4 | |
_o_EDIT FORM | Dynamische Formulare | v17 R4 | |
_o_LIST USER FORMS | Dynamische Formulare | v17 R4 | |
Webserver-Thema: | |||
_O_WEB Get session process count | Skalierbare Sessions verwenden | v18 R6 | |
4D Internet Commands: | |||
POP3 Review Mail commands | POP3Transporter class | v18 | |
SMTP Send Mail commands | SMTPTransporter class | v18 R6 | |
IMAP Review Mail commands | IMAPTransporter class | v19 | |
Downloaded Mail commands | IMAPTransporter class, POP3Transporter class | v19 | |
File Transfer commands | SystemWorker class | v20 |
Diese Befehle in alphabetischer Reihenfolge finden Sie im Anhang Überholte Befehle des Handbuchs 4D Programmiersprache.
Ab 4D v20 ist die Übereinstimmung Ihres Datenbankcodes mit der Objektnotation obligatorisch. Wenn Sie versuchen, eine Datenbank zu konvertieren, in der die Option Objektnotation für den Zugriff auf Objekteigenschaften verwenden noch nicht aktiviert war (Kompatibilitätsmodus, siehe Seite Kompatibilität), zeigt 4D ein Dialogfenster an, in dem Sie die Option vorübergehend aktivieren können, um die Datenbank öffnen zu können. Sie müssen die Option immer noch explizit aktivieren, um sie dauerhaft zuzulassen -- es wird jedoch empfohlen, die Kompatibilität der Applikation vorher mit dem MSC zu überprüfen.
Wenn Sie auf Abbrechen klicken oder wenn die Datenbank den Zugriff auf den Entwicklungsmodus nicht zulässt (kompilierte Datenbank, kein Zugriff im Entwurf...), wird der Fehler -10537 erzeugt und die Datenbank wird nicht geöffnet.
Hinweis: Der Kompatibilitätsmodus war nur in binären Datenbanken verfügbar.
Der PDFCreator Treiber ist ab 4D v20 überholt. Windows 10 und höhere Versionen enthalten einen nativen PDF-Treiber. Die Konstante PDFCreator Druckername wurde umbenannt in _o_PDFCreator Printer name.
Several PHP modules have been removed from the included PHP interpreter in 4D v20, most of them because they are no longer needed or deprecated: DOM (Document Object Model), Iconv, LibXML, LibXSLT, SimpleXML, GD (Graphics Draw) Library, XML (eXtensible Markup Language), XMLreader, XMLwriter, WDDX (Web Distributed Data eXchange), Zlib, Zip. If your application was using a removed module, you might need to use relevant 4D commands or an external FastCGI-php interpreter. For more information, please refer to the PHP modules support section.
Seit 4D v19 R4 ist aufgrund der Unterstützung des ternären Operators der Doppelpunkt ":" in Variablen-, Feld-, Konstanten-, Funktions-, Plugin- und Projektmethodennamen nicht mehr erlaubt.
Ab 4D v19 ist das 4D ODBC Pro Plug-in nicht mehr auf allen Plattformen verfügbar. Wir empfehlen, den eingebauten ODBC/SQL Pass-Through (siehe SQL LOGIN und Einführung in SQL Befehle) oder die 4D REST API zu verwenden, um ODBC/SQL Konnektivitätsfunktionen zu handhaben.
Ab 4D v19 ist das 4D for OCI Plug-in nicht mehr unter macOS verfügbar. Wir empfehlen, den eingebauten ODBC/SQL Pass-Through (siehe SQL LOGIN und Einführung in SQL Befehle) oder die 4D REST API zu verwenden, um Konnektivitätsfunktionen auf dieser Plattform zu handhaben.
Ab 4D v19 ist der 4D ODBC Treiber unter macOS nicht mehr verfügbar. Wir empfehlen die Verwendung des 4D REST API für den externen Datenzugriff auf diese Plattform.
Die Speicheroption Außerhalb der Datendatei wird für Felder vom Typ Objekt nicht mehr unterstützt (siehe Speichern im Datensatz, in der Datendatei, außerhalb der Datendatei). Wenn diese Option für ein Objektfeld ausgewählt wurde, wird es automatisch in In Datendatei konvertiert und für neue Datensätze verwendet. Vorhandene Daten in Objektfeldern werden beim Speichern des übergeordneten Datensatzes transparent an der neuen Position neu geschrieben. Um zu erzwingen, dass alle Datensätze auf einmal umgeschrieben werden, können Sie die Datendatei mit der Option "Datensätze aktualisieren" verdichten.
Nach jahrelangem Einsatz ist es an der Zeit, sich von ihnen zu verabschieden: Interprozessvariablen sind jetzt überholt. Die Verwendung von Interprozess-Variablen wird in 4D Projekten nicht empfohlen, da sie von präemptiven Prozessen nicht zur Verfügung stehen und nicht für den Umgang mit komplexen Werten wie Arrays, Objekten oder Collections (wenn sie nicht gemeinsam genutzt werden) von mehreren Prozessen gleichzeitig geeignet sind. Schließlich neigen sie dazu, den Code weniger wartbar zu machen. Um Objekt- und Collection-Werte zwischen Prozessen auszutauschen, empfehlen wir dringend die Verwendung von shared Objects und Collections und/oder des Befehls Storage.
Ab 4D Write Pro v19 R4 können Sie Zeilenumbrüche verarbeiten. Um Verwechslungen mit Absatz- und Tabellenumbrüchen zu vermeiden, werden alle Umbrüche jetzt über spezielle Konstanten und Standardaktionen behandelt (siehe 4D Write Pro Attribute und 4D Write Pro Standardaktionen verwenden). Die bisherige generische Konstante (_o_wk page break inside) und die Standardaktion (avoidPageBreakInsideEnabled) sind überholt und werden nur noch zur Wahrung der Kompatibilität unterstützt.
Ab 4D v17 R4 sind Benutzerformulare überholt. Für anpassbare Benutzeroberflächen empfehlen wir jetzt, dynamische Formulare zu verwenden (siehe Dynamische Formulare des Handbuchs 4D Designmodus). Alle Befehle im Kapitel "Benutzerformulare" sind überholt.
Zur Wahrung der Kompatibilität werden Benutzerformulare noch unterstützt, sie sollten aber nicht mehr verwendet werden. Denn dieses Feature wird in zukünftigen Releases entfernt.
In früheren 4D Versionen hat der Web Server automatisch den Wert von Variablen, die über ein Web Formular oder eine URL gesendet wurden, in 4D Variablen kopiert, wenn sie denselben Namen hatten.
Dieses Prinzip wird aus Sicherheitsgründen in 4D v14 nicht beibehalten, d.h. der Wert von Web Variablen wird nicht mehr automatisch 4D Variablen zugewiesen. Um über POST oder GET gesendete Variablen zu finden, müssen Sie ausschließlich den Befehl WEB GET VARIABLES verwenden.
Um per POST übertragene Dateien zu erhalten, müssen Sie den Befehl WEB GET BODY PART bzw. WEB Get body part count verwenden.
Hinweis: Die dynamische Zuweisung ist in 4D Anwendungen, die mit v13.4 oder höher erstellt wurden, standardmäßig deaktiviert.
Die bisherige Funktionsweise wird zur Wahrung der Kompatibilität standardmäßig in Anwendungen beibehalten, die mit einer Version älter als 13.4 erstellt wurden. Sie können bei Bedarf in den Datenbank-Eigenschaften auf der Seite Kompatibilität die Option Automatische Zuweisung von Variablen deaktivieren.
Da diese Funktionsweise überholt und unsicher ist, empfehlen wir dringend, diese Option in konvertierten Anwendungen zu deaktivieren (und Ihren Code bei Bedarf anzupassen).
4D warnt Entwickler schon seit einigen Hauptversionen (Major Releases) davor, Untertabellen zu verwenden. Schon seit 4D v11 lässt sich kein Datenfeld vom Typ Untertabelle mehr anlegen. Unterdatensätze haben einige bekannte Einschränkungen. Sie werden z.B. immer in den Speicher geladen und nicht von den Befehlen SEND RECORD oder DUPLICATE RECORD verwaltet.
Wir planen vorerst nicht, die Unterstützung von Untertabellen zu entfernen. Entwickler sollten aber auf alle Fälle ihre Untertabellen in reguläre N-> Tabellen umwandeln, da sie in einer zukünftigen 4D Hauptversion entfernt werden.
Im allgemeinen gibt es zwei Vorgehensweisen zum Entfernen von Untertabellen. Hier ein ein kurzer Überblick:
“den Code an den erforderlichen Stellen ändern” bedeutet im Einzelnen:
Hinweis: Ab 4D v14 R3 können Sie dem speziellen Feld "id_added_by_converter" selbst Werte zuweisen. Dieses Feld fügt 4D automatisch hinzu, wenn eine Anwendung mit Untertabellen konvertiert wird. So können Sie die spezielle Verknüpfung "Untertabelle Verknüpfung" beibehalten und verknüpfte Datensätze ändern oder hinzufügen, als ob sie normale Datensätze wären und müssen nicht mehr überholte Befehle wie _o_CREATE SUBRECORD verwenden. Sind dann all Ihre Methoden aktualisiert, können Sie diese spezielle Verknüpfung durch eine reguläre Verknüpfung ersetzen, ohne Ihren Code zu verändern.
Ab 4D v16 R6 sind auf Mac OS 9 basierende APIs zur Datei- und Ordnerverwaltung überholt. Diese APIs sind bei Apple schon seit längerer Zeit überholt.
4D Befehle, die auf den alten APIs basieren, wurden entsprechend umbenannt: _o_Document type, _o_Document creator, _o_SET DOCUMENT TYPE, _o_SET DOCUMENT CREATOR und _o_MAP FILE TYPES. Diese Befehle werden zur Wahrung der Kompatibilität beibehalten. Sie sind jedoch überholt und sollten nicht mehr verwendet werden. 4D enthält zwei neue Befehle zum Verwalten von Pfadnamen und Dateiendungen: Path to object und Object to path.
Standardaktionen wurden in 4D v16 R3 intern umgestaltet. Sie basieren jetzt auf Stringmustern und unterstützen Parameter. Weitere Informationen dazu finden Sie im Abschnitt Standardaktionen.
In Ihren konvertierten Anwendungen werden Standardaktionen transparent an das neue Design angepasst. In der 4D Programmiersprache basierten Standardaktionen bisher auf Code-Werten. Dieses Prinzip ist überholt und sollte nicht mehr eingesetzt werden:
Dies ist eine weitere alte Mac OS Technologie, die seit Mac OS X 10.4 überholt ist (Tiger, 2005). Ressourcen dienten zum Speichern von Strukturdaten, wie Text und Strings zur Lokalisierung, Icons, etc. Im Grunde genommen sind aber nicht die Ressourcen ansich überholt, sondern vielmehr die Unterstützung einer eigenen Datei auf der Festplatte, auch bekannt als Resource Fork. Sie ist Teil des Mac OS Dateisystems, und Apple hat seit Einführung von OS X die Unterstützung dieser Datei eingestellt, da sie mit anderen Dateisystemen, wie Unix oder Windows, nicht kompatibel ist und beim Übertragen von Dateien über das Netzwerk eine Menge Probleme verursachte.
Unter Windows wird dieser Mechanismus emuliert und Mac Ressourcen liegen in einer .RSR Datei.
Wir raten jedoch davon ab, diesen alten Mechanismus weiter zu verwenden - auch wenn es noch APIs zum Verwalten dieser Ressourcen gibt (und Mac OS in Data Forks gespeicherte Ressourcen transparent verwaltet). Dafür gibt es folgende Gründe:
Befehle, die Ressourcen schreiben oder erstellen, werden nicht mehr unterstützt.
Die meisten 4D Applikationen, die Ressourcen nutzen, verwenden String Listen, d.h. ‘STR#’ Ressourcen. 4D bietet Tools, um einfach von STR# zu XLIFF zu wechseln:
Für andere Arten von Ressourcen gilt folgendes:
Produkt: 4D
Überholte und entfernte Funktionalitäten ( 4D v20)