use of com.robotoworks.mechanoid.db.sqliteModel.ResultColumn in project mechanoid by robotoworks.
the class ActiveRecordGenerator method _generateParcelDeserializationStatements.
protected CharSequence _generateParcelDeserializationStatements(final CreateViewStatement stmt) {
StringConcatenation _builder = new StringConcatenation();
int counter = (-1);
_builder.newLineIfNotEmpty();
ArrayList<ColumnSource> cols = ModelUtil.getViewResultColumns(stmt);
_builder.newLineIfNotEmpty();
{
final Function1<ColumnSource, Boolean> _function = new Function1<ColumnSource, Boolean>() {
public Boolean apply(final ColumnSource it) {
String _name = it.getName();
boolean _equals = _name.equals("_id");
return Boolean.valueOf((!_equals));
}
};
Iterable<ColumnSource> _filter = IterableExtensions.<ColumnSource>filter(cols, _function);
for (final ColumnSource item : _filter) {
ResultColumn col = ((ResultColumn) item);
_builder.newLineIfNotEmpty();
ColumnType type = ModelUtil.getInferredColumnType(col);
_builder.newLineIfNotEmpty();
{
boolean _equals = Objects.equal(type, ColumnType.BOOLEAN);
if (_equals) {
_builder.append("m");
String _name = col.getName();
String _pascalize = Strings.pascalize(_name);
_builder.append(_pascalize, "");
_builder.append(" = (in.readInt() > 0);");
_builder.newLineIfNotEmpty();
} else {
boolean _equals_1 = Objects.equal(type, ColumnType.BLOB);
if (_equals_1) {
_builder.append("m");
String _name_1 = col.getName();
String _pascalize_1 = Strings.pascalize(_name_1);
_builder.append(_pascalize_1, "");
_builder.append(" = in.createByteArray();");
_builder.newLineIfNotEmpty();
} else {
_builder.append("m");
String _name_2 = col.getName();
String _pascalize_2 = Strings.pascalize(_name_2);
_builder.append(_pascalize_2, "");
_builder.append(" = in.read");
String _javaTypeName = ModelUtil.toJavaTypeName(type);
String _pascalize_3 = Strings.pascalize(_javaTypeName);
_builder.append(_pascalize_3, "");
_builder.append("();");
_builder.newLineIfNotEmpty();
}
}
}
}
}
_builder.newLine();
_builder.append("boolean[] dirtyFlags = new boolean[");
int _size = cols.size();
int _minus = (_size - 1);
_builder.append(_minus, "");
_builder.append("];");
_builder.newLineIfNotEmpty();
_builder.append("in.readBooleanArray(dirtyFlags);");
_builder.newLine();
{
final Function1<ColumnSource, Boolean> _function_1 = new Function1<ColumnSource, Boolean>() {
public Boolean apply(final ColumnSource it) {
String _name = it.getName();
boolean _equals = _name.equals("_id");
return Boolean.valueOf((!_equals));
}
};
Iterable<ColumnSource> _filter_1 = IterableExtensions.<ColumnSource>filter(cols, _function_1);
for (final ColumnSource col_1 : _filter_1) {
_builder.append("m");
String _name_3 = col_1.getName();
String _pascalize_4 = Strings.pascalize(_name_3);
_builder.append(_pascalize_4, "");
_builder.append("Dirty = dirtyFlags[");
_builder.append(counter = (counter + 1), "");
_builder.append("];");
_builder.newLineIfNotEmpty();
}
}
return _builder;
}
use of com.robotoworks.mechanoid.db.sqliteModel.ResultColumn in project mechanoid by robotoworks.
the class ContentProviderContractGenerator method _generateBuilderSetters.
protected CharSequence _generateBuilderSetters(final CreateViewStatement stmt) {
StringConcatenation _builder = new StringConcatenation();
ArrayList<ColumnSource> cols = ModelUtil.getViewResultColumns(stmt);
_builder.newLineIfNotEmpty();
{
final Function1<ColumnSource, Boolean> _function = new Function1<ColumnSource, Boolean>() {
public Boolean apply(final ColumnSource it) {
String _name = it.getName();
boolean _equals = _name.equals("_id");
return Boolean.valueOf((!_equals));
}
};
Iterable<ColumnSource> _filter = IterableExtensions.<ColumnSource>filter(cols, _function);
for (final ColumnSource item : _filter) {
ResultColumn col = ((ResultColumn) item);
_builder.newLineIfNotEmpty();
ColumnType type = ModelUtil.getInferredColumnType(col);
_builder.newLineIfNotEmpty();
_builder.append("public Builder set");
String _name = col.getName();
String _pascalize = Strings.pascalize(_name);
_builder.append(_pascalize, "");
_builder.append("(");
String _javaTypeName = ModelUtil.toJavaTypeName(type);
_builder.append(_javaTypeName, "");
_builder.append(" value) {");
_builder.newLineIfNotEmpty();
_builder.append("\t");
_builder.append("mValues.put(");
String _name_1 = stmt.getName();
String _pascalize_1 = Strings.pascalize(_name_1);
_builder.append(_pascalize_1, "\t");
_builder.append(".");
String _name_2 = col.getName();
String _underscore = Strings.underscore(_name_2);
String _upperCase = _underscore.toUpperCase();
_builder.append(_upperCase, "\t");
_builder.append(", value);");
_builder.newLineIfNotEmpty();
_builder.append("\t");
_builder.append("return this;");
_builder.newLine();
_builder.append("}");
_builder.newLine();
}
}
return _builder;
}
use of com.robotoworks.mechanoid.db.sqliteModel.ResultColumn in project mechanoid by robotoworks.
the class ModelUtil method getInferredColumnType.
public static ColumnType getInferredColumnType(final ResultColumn col) {
Expression expr = col.getExpression();
boolean _matched = false;
if (!_matched) {
if (expr instanceof CastExpression) {
_matched = true;
SqliteDataType _type = ((CastExpression) expr).getType();
return ModelUtil.toColumnType(_type);
}
}
if (!_matched) {
if (expr instanceof ColumnSourceRef) {
_matched = true;
ColumnSource _column = ((ColumnSourceRef) expr).getColumn();
if ((_column instanceof ResultColumn)) {
ColumnSource _column_1 = ((ColumnSourceRef) expr).getColumn();
ColumnType _inferredColumnType = ModelUtil.getInferredColumnType(((ResultColumn) _column_1));
return ((ColumnType) _inferredColumnType);
} else {
ColumnSource _column_2 = ((ColumnSourceRef) expr).getColumn();
return ((ColumnDef) _column_2).getType();
}
}
}
if (!_matched) {
if (expr instanceof ExprConcat) {
_matched = true;
return ColumnType.TEXT;
}
}
if (!_matched) {
if (expr instanceof Function) {
_matched = true;
boolean _or = false;
boolean _or_1 = false;
boolean _or_2 = false;
boolean _or_3 = false;
boolean _or_4 = false;
String _name = ((Function) expr).getName();
boolean _equalsIgnoreCase = _name.equalsIgnoreCase("count");
if (_equalsIgnoreCase) {
_or_4 = true;
} else {
String _name_1 = ((Function) expr).getName();
boolean _equalsIgnoreCase_1 = _name_1.equalsIgnoreCase("length");
_or_4 = _equalsIgnoreCase_1;
}
if (_or_4) {
_or_3 = true;
} else {
String _name_2 = ((Function) expr).getName();
boolean _equalsIgnoreCase_2 = _name_2.equalsIgnoreCase("random");
_or_3 = _equalsIgnoreCase_2;
}
if (_or_3) {
_or_2 = true;
} else {
String _name_3 = ((Function) expr).getName();
boolean _equalsIgnoreCase_3 = _name_3.equalsIgnoreCase("last_insert_rowid");
_or_2 = _equalsIgnoreCase_3;
}
if (_or_2) {
_or_1 = true;
} else {
String _name_4 = ((Function) expr).getName();
boolean _equalsIgnoreCase_4 = _name_4.equalsIgnoreCase("changes");
_or_1 = _equalsIgnoreCase_4;
}
if (_or_1) {
_or = true;
} else {
String _name_5 = ((Function) expr).getName();
boolean _equalsIgnoreCase_5 = _name_5.equalsIgnoreCase("total_changes");
_or = _equalsIgnoreCase_5;
}
if (_or) {
return ColumnType.INTEGER;
} else {
boolean _or_5 = false;
boolean _or_6 = false;
boolean _or_7 = false;
boolean _or_8 = false;
boolean _or_9 = false;
String _name_6 = ((Function) expr).getName();
boolean _equalsIgnoreCase_6 = _name_6.equalsIgnoreCase("abs");
if (_equalsIgnoreCase_6) {
_or_9 = true;
} else {
String _name_7 = ((Function) expr).getName();
boolean _equalsIgnoreCase_7 = _name_7.equalsIgnoreCase("avg");
_or_9 = _equalsIgnoreCase_7;
}
if (_or_9) {
_or_8 = true;
} else {
String _name_8 = ((Function) expr).getName();
boolean _equalsIgnoreCase_8 = _name_8.equalsIgnoreCase("round");
_or_8 = _equalsIgnoreCase_8;
}
if (_or_8) {
_or_7 = true;
} else {
String _name_9 = ((Function) expr).getName();
boolean _equalsIgnoreCase_9 = _name_9.equalsIgnoreCase("sum");
_or_7 = _equalsIgnoreCase_9;
}
if (_or_7) {
_or_6 = true;
} else {
String _name_10 = ((Function) expr).getName();
boolean _equalsIgnoreCase_10 = _name_10.equalsIgnoreCase("total");
_or_6 = _equalsIgnoreCase_10;
}
if (_or_6) {
_or_5 = true;
} else {
String _name_11 = ((Function) expr).getName();
boolean _equalsIgnoreCase_11 = _name_11.equalsIgnoreCase("likelihood");
_or_5 = _equalsIgnoreCase_11;
}
if (_or_5) {
return ColumnType.REAL;
} else {
boolean _or_10 = false;
String _name_12 = ((Function) expr).getName();
boolean _equalsIgnoreCase_12 = _name_12.equalsIgnoreCase("randomblob");
if (_equalsIgnoreCase_12) {
_or_10 = true;
} else {
String _name_13 = ((Function) expr).getName();
boolean _equalsIgnoreCase_13 = _name_13.equalsIgnoreCase("zeroblob");
_or_10 = _equalsIgnoreCase_13;
}
if (_or_10) {
return ColumnType.BLOB;
}
}
}
return ColumnType.TEXT;
}
}
return ColumnType.TEXT;
}
use of com.robotoworks.mechanoid.db.sqliteModel.ResultColumn in project mechanoid by robotoworks.
the class ActiveRecordGenerator method _generateParcelSerializationStatements.
protected CharSequence _generateParcelSerializationStatements(final CreateViewStatement stmt) {
StringConcatenation _builder = new StringConcatenation();
ArrayList<ColumnSource> cols = ModelUtil.getViewResultColumns(stmt);
_builder.newLineIfNotEmpty();
{
final Function1<ColumnSource, Boolean> _function = new Function1<ColumnSource, Boolean>() {
public Boolean apply(final ColumnSource it) {
String _name = it.getName();
boolean _equals = _name.equals("_id");
return Boolean.valueOf((!_equals));
}
};
Iterable<ColumnSource> _filter = IterableExtensions.<ColumnSource>filter(cols, _function);
for (final ColumnSource item : _filter) {
ResultColumn col = ((ResultColumn) item);
_builder.newLineIfNotEmpty();
ColumnType type = ModelUtil.getInferredColumnType(col);
_builder.newLineIfNotEmpty();
{
boolean _equals = Objects.equal(type, ColumnType.BOOLEAN);
if (_equals) {
_builder.append("dest.writeInt(m");
String _name = col.getName();
String _pascalize = Strings.pascalize(_name);
_builder.append(_pascalize, "");
_builder.append(" ? 1 : 0);");
_builder.newLineIfNotEmpty();
} else {
boolean _equals_1 = Objects.equal(type, ColumnType.BLOB);
if (_equals_1) {
_builder.append("dest.writeByteArray(m");
String _name_1 = col.getName();
String _pascalize_1 = Strings.pascalize(_name_1);
_builder.append(_pascalize_1, "");
_builder.append(");");
_builder.newLineIfNotEmpty();
} else {
_builder.append("dest.write");
String _javaTypeName = ModelUtil.toJavaTypeName(type);
String _pascalize_2 = Strings.pascalize(_javaTypeName);
_builder.append(_pascalize_2, "");
_builder.append("(m");
String _name_2 = col.getName();
String _pascalize_3 = Strings.pascalize(_name_2);
_builder.append(_pascalize_3, "");
_builder.append(");");
_builder.newLineIfNotEmpty();
}
}
}
}
}
_builder.append("dest.writeBooleanArray(new boolean[] {");
_builder.newLine();
{
final Function1<ColumnSource, Boolean> _function_1 = new Function1<ColumnSource, Boolean>() {
public Boolean apply(final ColumnSource it) {
String _name = it.getName();
boolean _equals = _name.equals("_id");
return Boolean.valueOf((!_equals));
}
};
Iterable<ColumnSource> _filter_1 = IterableExtensions.<ColumnSource>filter(cols, _function_1);
boolean _hasElements = false;
for (final ColumnSource col_1 : _filter_1) {
if (!_hasElements) {
_hasElements = true;
} else {
_builder.appendImmediate(",", "\t");
}
_builder.append("\t");
_builder.append("m");
String _name_3 = col_1.getName();
String _pascalize_4 = Strings.pascalize(_name_3);
_builder.append(_pascalize_4, "\t");
_builder.append("Dirty");
_builder.newLineIfNotEmpty();
}
}
_builder.append("});");
_builder.newLine();
return _builder;
}
use of com.robotoworks.mechanoid.db.sqliteModel.ResultColumn in project mechanoid by robotoworks.
the class ActiveRecordGenerator method _generateSetFromCursorStatements.
protected CharSequence _generateSetFromCursorStatements(final CreateViewStatement stmt) {
StringConcatenation _builder = new StringConcatenation();
ArrayList<ColumnSource> cols = ModelUtil.getViewResultColumns(stmt);
_builder.newLineIfNotEmpty();
{
final Function1<ColumnSource, Boolean> _function = new Function1<ColumnSource, Boolean>() {
public Boolean apply(final ColumnSource it) {
String _name = it.getName();
boolean _equals = _name.equals("_id");
return Boolean.valueOf((!_equals));
}
};
Iterable<ColumnSource> _filter = IterableExtensions.<ColumnSource>filter(cols, _function);
for (final ColumnSource item : _filter) {
ResultColumn col = ((ResultColumn) item);
_builder.newLineIfNotEmpty();
ColumnType type = ModelUtil.getInferredColumnType(col);
_builder.newLineIfNotEmpty();
{
boolean _equals = Objects.equal(type, ColumnType.BOOLEAN);
if (_equals) {
_builder.append("set");
String _name = col.getName();
String _pascalize = Strings.pascalize(_name);
_builder.append(_pascalize, "");
_builder.append("(c.getInt(Indices.");
String _name_1 = col.getName();
String _underscore = Strings.underscore(_name_1);
String _upperCase = _underscore.toUpperCase();
_builder.append(_upperCase, "");
_builder.append(") > 0);");
_builder.newLineIfNotEmpty();
} else {
boolean _equals_1 = Objects.equal(type, ColumnType.BLOB);
if (_equals_1) {
_builder.append("set");
String _name_2 = col.getName();
String _pascalize_1 = Strings.pascalize(_name_2);
_builder.append(_pascalize_1, "");
_builder.append("(c.getBlob(Indices.");
String _name_3 = col.getName();
String _underscore_1 = Strings.underscore(_name_3);
String _upperCase_1 = _underscore_1.toUpperCase();
_builder.append(_upperCase_1, "");
_builder.append("));");
_builder.newLineIfNotEmpty();
} else {
_builder.append("set");
String _name_4 = col.getName();
String _pascalize_2 = Strings.pascalize(_name_4);
_builder.append(_pascalize_2, "");
_builder.append("(c.get");
String _javaTypeName = ModelUtil.toJavaTypeName(type);
String _pascalize_3 = Strings.pascalize(_javaTypeName);
_builder.append(_pascalize_3, "");
_builder.append("(Indices.");
String _name_5 = col.getName();
String _underscore_2 = Strings.underscore(_name_5);
String _upperCase_2 = _underscore_2.toUpperCase();
_builder.append(_upperCase_2, "");
_builder.append("));");
_builder.newLineIfNotEmpty();
}
}
}
}
}
return _builder;
}
Aggregations