File: MySQLConn2.pas

package info (click to toggle)
mysql-gui-tools 5.0r12-1
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 105,540 kB
  • ctags: 50,897
  • sloc: sql: 348,439; pascal: 285,780; cpp: 94,578; ansic: 90,768; objc: 33,761; sh: 25,629; xml: 10,924; yacc: 10,755; java: 9,986; php: 2,806; python: 2,068; makefile: 1,945; perl: 3
file content (61 lines) | stat: -rw-r--r-- 1,449 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
unit MySQLConn2;

interface

uses
  MySQLConnection, myx_public_interface;

type
  TMySQLConn2 = class(TMySQLConn)

    function ConnectToServerWithConnection(var Conn: TMYX_USER_CONNECTION): Boolean;
  private
    function CheckConnectionData(Conn: TMYX_USER_CONNECTION): Boolean;
  end;

implementation

function TMySQLConn2.ConnectToServerWithConnection(
  var Conn: TMYX_USER_CONNECTION): Boolean;

var
  ConnRes: Integer;
  EnoughData: Boolean;

begin
  ConnRes := -1;
  Result := False;

  EnoughData := CheckConnectionData(Conn);
  if  EnoughData then // enough data to connect - dont show the dialog
  begin
    ConnRes := Connect(FMySQL, Conn, False);
    if(ConnRes = 1)then
      Result := True;
  end;

  // if autoconnectio failed or not enough data - show dialog
  if not EnoughData or (ConnRes <> 1)then
    ConnRes := ShowConnectToInstanceForm(Conn,
        FMySQL, True, False, True);

  if ConnRes = 1 then
  begin
    MySQLMajorVersion := myx_get_mysql_major_version(FMySQL);
    MySQLMinorVersion := myx_get_mysql_minor_version(FMySQL);

    Connected := True;
    ConnectedToLocalhost := (myx_is_localhost(Conn.hostname) = 1);
  end;
end;

function TMySQLConn2.CheckConnectionData(Conn: TMYX_USER_CONNECTION): Boolean;

begin
  Result :=
    (Length(Conn.username) > 0) and
    (Length(Conn.hostname) > 0) and
    (Conn.port > 0) and (Conn.port < 32768); 
end;

end.