For now, The Black Toolkit has ports for Windows and Linux, in native PC achitecture.
Its source code is in Object Pascal using Lazarus IDE, but it doesn't mean that some units cannot be compiled as a java library.
The FPCJVM compiler can compile a Object Pascal source code and output to Java (and Dalvik) Virtual Machine format. It has some restrictions, but it can be made.
Since The Black Toolkit 1.4 (May 2014) I have made some tests with FPCJVM and the source code of the tool.
I have seen the docs of androidlcl too, but writing for a native CPU achitecture instead of Java is not good for compatibility :(
My choice was not to use androidlcl, but a pure FPCJVM app using some units of the PC version of The Black Toolkit. Others units, like activities need to be new Java Classes, with a new interface and more useful for small screen resolutions.
Some parts of source need to be reallocated or rewrited for a concurrent build (PC and Android). It will take a lot of work, but it is very possible to goes well.
Search This Blog
Friday, October 24, 2014
Sunday, May 4, 2014
The Black Toolkit 1.4 is released today
The Black Toolkit is in constant evolution and it is released today. Containing new bugfixes and improvements from the last versions of the tool.
Saturday, April 26, 2014
The Black Toolkit 1.4 is almost ready for release
The Black Toolkit 1.4 will come with new improvements like the support for MySQL 5.5 and 5.6 with native drivers (non ODBC).
I've tested it also with MariaDB and it works, thanks for the new versions of Lazarus and SQLDb!
A new old icon of the app, from 1.0.7.1 is back! The new one always had drawing problems on Windows platform. Sorry!
We 'll spend next days fighting against bad behaviours of the past versions. Like saving a PHP Visual RAD Form, now it automatically closes the code popup window for the programmer go the navigator easily.
The SQL Client now remembers the last 20 connections made before.
The DAO Generator will have better compatibility with more than one DB vendor, because it will generate a method getGenerator() for getting the SQL for the generator (or sequence) for the table. You just need to override this method for each subclass to get the generator for the table in a encapsulated way with genID().
A sequence in Oracle is called this way:
select the_seq.nextval from dual
A generator in Firebird is called this way:
select gen_id(the_gen, 1) from rdb$database
I've tested it also with MariaDB and it works, thanks for the new versions of Lazarus and SQLDb!
A new old icon of the app, from 1.0.7.1 is back! The new one always had drawing problems on Windows platform. Sorry!
This is an Hybrid version in development. |
We 'll spend next days fighting against bad behaviours of the past versions. Like saving a PHP Visual RAD Form, now it automatically closes the code popup window for the programmer go the navigator easily.
The SQL Client now remembers the last 20 connections made before.
The DAO Generator will have better compatibility with more than one DB vendor, because it will generate a method getGenerator() for getting the SQL for the generator (or sequence) for the table. You just need to override this method for each subclass to get the generator for the table in a encapsulated way with genID().
A sequence in Oracle is called this way:
select the_seq.nextval from dual
A generator in Firebird is called this way:
select gen_id(the_gen, 1) from rdb$database
Friday, January 31, 2014
The Black Toolkit 1.2 is released
The Black Toolkit 1.2 is released is released containing new improvements and bugfixes, specially on the new SQL Client.
- Fixed some bugs.
- Supported new HTML5 events!
- SQL Client has new improvements.
Friday, January 24, 2014
Making Heavy Metal SQL Client recognize your DB through ODBC.
The Black Toolkit is made to be extensible, that means you can install XML files to add more functionality to the software.
To make SQL Client to work with another DB you need to make an XML for it, and place it in the sql\ installation dir of The Black Toolkit. There´s one file for DB:
<ondetect>Heavy Metal will detect the XML file to use if the DB it recognizes the query in ondetect tag. Must be a query just this DB recognizes</ondetect>
<ongettables>An SQL Query statement for getting the tables of the DB. You can return more than one column, such as database,schema,table_name (PostgreSQL) or database,table_name (MySQL) </ongettables>
<maptypes>
Types for SQL-to-java and java-to-SQL mapping made for the tool. Examples:
<map type="TEXT" javatype="String"/>
<map types="LONG" javatype="long" />
</maptypes>
<ongetfields>An SQL Query for getting the fields for a table. Heavy Metal will expand %1% and %2%... by the db/schema/table names returned by ongettables. The query must return the column name and type as in maptypes.</ongetfields>
<ongetpkfields>An SQL Query for getting the Primary key field names for a table. Heavy Metal will expand %1% and %2% ... by the schema/table names returned by ongettables.</ongetpkfields>
<ongetfkfields>An SQL Query for getting the imported fields for a column: Heavy metal will expand %1% and %2%... by the schema/table names returned by ongettables, and the %3% (or %4%) by the column name.
</ongetfkfields>
<sequencecmd>An SQL Query for access the sequence or generator of a table. This is for the SQL importer.</sequencecmd>
<onselect>An SQL Query for making a SELECT statement of a table</onselect>
<object name="ObjName" global="true" query="..." >
This will declare an database object. You can declare object as much as you like.
name=Name of the object (Like Indexes, Views, Functions...).
global="false" if it depends of a table (like an Index), "true" if does not (like a Function).
query=SQL for query these objects. Must return a full list of details of the objects in the database.
<action name="Action1" helpurl="...">
SQL for the user can make actions for the object. Like CREATE, ALTER, etc. You can declare action as much you like. Heavy Metal will expand %1% by the db.table name and %3%, %4%,... for the query return (for non global objects). And %1%,... by the query return (for global objects).
</action>
</object>
To make SQL Client to work with another DB you need to make an XML for it, and place it in the sql\ installation dir of The Black Toolkit. There´s one file for DB:
<ondetect>Heavy Metal will detect the XML file to use if the DB it recognizes the query in ondetect tag. Must be a query just this DB recognizes</ondetect>
<ongettables>An SQL Query statement for getting the tables of the DB. You can return more than one column, such as database,schema,table_name (PostgreSQL) or database,table_name (MySQL) </ongettables>
<maptypes>
Types for SQL-to-java and java-to-SQL mapping made for the tool. Examples:
<map type="TEXT" javatype="String"/>
<map types="LONG" javatype="long" />
</maptypes>
<ongetfields>An SQL Query for getting the fields for a table. Heavy Metal will expand %1% and %2%... by the db/schema/table names returned by ongettables. The query must return the column name and type as in maptypes.</ongetfields>
<ongetpkfields>An SQL Query for getting the Primary key field names for a table. Heavy Metal will expand %1% and %2% ... by the schema/table names returned by ongettables.</ongetpkfields>
<ongetfkfields>An SQL Query for getting the imported fields for a column: Heavy metal will expand %1% and %2%... by the schema/table names returned by ongettables, and the %3% (or %4%) by the column name.
</ongetfkfields>
<sequencecmd>An SQL Query for access the sequence or generator of a table. This is for the SQL importer.</sequencecmd>
<onselect>An SQL Query for making a SELECT statement of a table</onselect>
<object name="ObjName" global="true" query="..." >
This will declare an database object. You can declare object as much as you like.
name=Name of the object (Like Indexes, Views, Functions...).
global="false" if it depends of a table (like an Index), "true" if does not (like a Function).
query=SQL for query these objects. Must return a full list of details of the objects in the database.
<action name="Action1" helpurl="...">
SQL for the user can make actions for the object. Like CREATE, ALTER, etc. You can declare action as much you like. Heavy Metal will expand %1% by the db.table name and %3%, %4%,... for the query return (for non global objects). And %1%,... by the query return (for global objects).
</action>
</object>
Monday, January 13, 2014
Importing data with foreign data wrappers on PostgreSQL
Foreign data wrappers is a new feature of PostgreSQL 9.1. It serves to read data from external data sources. The data sources can be...
Oh! http://wiki.postgresql.org/wiki/Foreign_data_wrappers
The list is extense! but will need to compile the extension from source, in a Linux server is easy. In Windows you ´ll need MinGW.
There´s 2 FDW which comes with PostgreSQL 9.3 for Windows: the file_fdw and postgres_fdw.
create extension file_fdw;
create server files foreign data wrapper file_fdw;
create foreign table foo_csv (
field1 varchar(13),
field2 varchar(50),
...
) server files options(format 'csv', encoding 'windows-1252', header 'true', delimiter ';', quote '"');
For Postgres_fdw here a example:
create extension postgres_fdw;
create server pgserver foreign data wrapper postgres_fdw options( host 'myhost', port '5432', dbname 'mydb');
create user mapping for myuser server pgserver options(user 'postgres', password '##@%¨$&¨'¨);
create foreign table my_foreign_table (
id int,
datet timestamp,
...
) server pgserver;
For copying data to a real table you can give a simple command:
create table foo as (select * from foo_csv where field2='E467');
Oh! http://wiki.postgresql.org/wiki/Foreign_data_wrappers
The list is extense! but will need to compile the extension from source, in a Linux server is easy. In Windows you ´ll need MinGW.
There´s 2 FDW which comes with PostgreSQL 9.3 for Windows: the file_fdw and postgres_fdw.
create extension file_fdw;
create server files foreign data wrapper file_fdw;
create foreign table foo_csv (
field1 varchar(13),
field2 varchar(50),
...
) server files options(format 'csv', encoding 'windows-1252', header 'true', delimiter ';', quote '"');
For Postgres_fdw here a example:
create extension postgres_fdw;
create server pgserver foreign data wrapper postgres_fdw options( host 'myhost', port '5432', dbname 'mydb');
create user mapping for myuser server pgserver options(user 'postgres', password '##@%¨$&¨'¨);
create foreign table my_foreign_table (
id int,
datet timestamp,
...
) server pgserver;
For copying data to a real table you can give a simple command:
create table foo as (select * from foo_csv where field2='E467');
Subscribe to:
Posts (Atom)