Mercurial > projects > qtd
diff generator/typesystem_sql-java.xml @ 1:e78566595089
initial import
author | mandel |
---|---|
date | Mon, 11 May 2009 16:01:50 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/generator/typesystem_sql-java.xml Mon May 11 16:01:50 2009 +0000 @@ -0,0 +1,97 @@ +<?xml version="1.0"?> +<typesystem package="qt.sql" default-superclass="qt.QtJambiObject"> + <inject-code> + qt.Utilities.loadQtLibrary("QtSql"); + </inject-code> + + + + <value-type name="QSqlDatabase"> + <inject-code> + <import-file name="typesystem_sql-java.java" quote-after-line="class QSqlDatabase___" quote-before-line="}// class"/> + </inject-code> + <modify-function signature="addDatabase(QSqlDriver*,QString)"> + <modify-argument index="1"> + <define-ownership class="java" owner="c++"/> + </modify-argument> + </modify-function> + <modify-function signature="contains(QString)"> + <modify-argument index="1"> + <replace-default-expression with="defaultConnection()"/> + </modify-argument> + </modify-function> + <modify-function signature="addDatabase(QString,QString)"> + <modify-argument index="2"> + <replace-default-expression with="defaultConnection()"/> + </modify-argument> + </modify-function> + <modify-function signature="addDatabase(QSqlDriver *,QString)"> + <modify-argument index="2"> + <replace-default-expression with="defaultConnection()"/> + </modify-argument> + </modify-function> + <modify-function signature="database(QString,bool)"> + <modify-argument index="1"> + <replace-default-expression with="defaultConnection()"/> + </modify-argument> + </modify-function> + <modify-field name="defaultConnection"> + <access modifier="private"/> + <rename to="defaultConnection_private"/> + </modify-field> + + </value-type> + + <object-type name="QSqlTableModel"> + + <template name="sql.convert_sqlrecord_reference_to_java"> + jobject %out = qtjambi_from_object(__jni_env, &%in, "QSqlRecord", "com/trolltech/qt/sql/", false); + Q_ASSERT(%out); + </template> + + <template name="sql.convert_sqlrecord_reference_from_java"> + QSqlRecord *__ptr_record = (QSqlRecord *) qtjambi_to_object(__jni_env, %in); + + QSqlRecord dummy; + QSqlRecord &%out = __ptr_record == 0 ? dummy : *__ptr_record; + </template> + + <modify-function signature="beforeInsert(QSqlRecord&)"> + <modify-argument index="1"> + <replace-type modified-type="qt.sql.QSqlRecord"/> + <conversion-rule class="shell"> + <insert-template name="sql.convert_sqlrecord_reference_to_java"/> + </conversion-rule> + <conversion-rule class="native"> + <insert-template name="sql.convert_sqlrecord_reference_from_java"/> + </conversion-rule> + </modify-argument> + </modify-function> + + <modify-function signature="beforeUpdate(int,QSqlRecord&)"> + <modify-argument index="2"> + <replace-type modified-type="qt.sql.QSqlRecord"/> + <conversion-rule class="shell"> + <insert-template name="sql.convert_sqlrecord_reference_to_java"/> + </conversion-rule> + <conversion-rule class="native"> + <insert-template name="sql.convert_sqlrecord_reference_from_java"/> + </conversion-rule> + </modify-argument> + </modify-function> + + <modify-function signature="primeInsert(int,QSqlRecord&)"> + <modify-argument index="2"> + <replace-type modified-type="qt.sql.QSqlRecord"/> + <conversion-rule class="shell"> + <insert-template name="sql.convert_sqlrecord_reference_to_java"/> + </conversion-rule> + <conversion-rule class="native"> + <insert-template name="sql.convert_sqlrecord_reference_from_java"/> + </conversion-rule> + </modify-argument> + </modify-function> + + </object-type> + +</typesystem>