# HG changeset patch # User eldar_ins@eldar-laptop # Date 1261522948 -18000 # Node ID 91ed8edd442e4879a5bd792b799a355678c00f7a # Parent 04b52676b45f1fce83ae60e03976b15f2663428d work on QStringList diff -r 04b52676b45f -r 91ed8edd442e generator/abstractmetalang.cpp --- a/generator/abstractmetalang.cpp Sun Dec 13 06:24:55 2009 +0500 +++ b/generator/abstractmetalang.cpp Wed Dec 23 04:02:28 2009 +0500 @@ -1905,10 +1905,13 @@ if (isConstant()) minimalSignature += "const "; minimalSignature += typeEntry()->qualifiedCppName(); - if (hasInstantiations()) { + if (hasInstantiations() && + (static_cast(typeEntry()))->type() != ContainerTypeEntry::StringListContainer) + { QList instantiations = this->instantiations(); minimalSignature += "<"; - for (int i=0;i 0) minimalSignature += ","; minimalSignature += instantiations.at(i)->minimalSignature(); diff -r 04b52676b45f -r 91ed8edd442e generator/dgenerator.cpp --- a/generator/dgenerator.cpp Sun Dec 13 06:24:55 2009 +0500 +++ b/generator/dgenerator.cpp Wed Dec 23 04:02:28 2009 +0500 @@ -2708,7 +2708,7 @@ bool hasDefault = false; do // need this to look for default arguments and generate extra signatures { - if (i || j) + if (j) s << ", "; s << endl << INDENT << " \"" << meta_funcs.at(i)->minimalSignature(j) << "\""; AbstractMetaArgumentList args = meta_funcs.at(i)->arguments(); diff -r 04b52676b45f -r 91ed8edd442e generator/typesystem_core.xml --- a/generator/typesystem_core.xml Sun Dec 13 06:24:55 2009 +0500 +++ b/generator/typesystem_core.xml Wed Dec 23 04:02:28 2009 +0500 @@ -2290,7 +2290,7 @@ - - + - + diff -r 04b52676b45f -r 91ed8edd442e generator/typesystem_phonon.xml --- a/generator/typesystem_phonon.xml Sun Dec 13 06:24:55 2009 +0500 +++ b/generator/typesystem_phonon.xml Wed Dec 23 04:02:28 2009 +0500 @@ -75,7 +75,7 @@ - + diff -r 04b52676b45f -r 91ed8edd442e generator/typesystem_xmlpatterns.xml --- a/generator/typesystem_xmlpatterns.xml Sun Dec 13 06:24:55 2009 +0500 +++ b/generator/typesystem_xmlpatterns.xml Wed Dec 23 04:02:28 2009 +0500 @@ -125,7 +125,7 @@ - + diff -r 04b52676b45f -r 91ed8edd442e qt/qtd/MetaMarshall.d --- a/qt/qtd/MetaMarshall.d Sun Dec 13 06:24:55 2009 +0500 +++ b/qt/qtd/MetaMarshall.d Wed Dec 23 04:02:28 2009 +0500 @@ -2,8 +2,14 @@ import std.traits; +// utilities // shouldn't be here +public bool startsWith(T)(T[] source, T[] pattern) +{ + return source.length >= pattern.length && source[0 .. pattern.length] == pattern[]; +} + string __toString(long v) { if (v == 0) @@ -30,6 +36,16 @@ return ret; } +template templateParam(U : V!(U), alias V) +{ + alias U templateParam; +} + + +/* + * actual stuff + */ + template isQObjectType(T) // is a QObject type that belongs to the library { enum isQObjectType = is(T.__isQObjectType); @@ -55,6 +71,11 @@ enum isStringType = is(T == string); } +template isQList(T) +{ + enum isQList = startsWith(Unqual!(T).stringof, "QList!"); +} + // converts an argumnent from C++ to D in qt_metacall string metaCallArgument(T)(string ptr) { @@ -76,6 +97,8 @@ return T.stringof ~ "*"; else static if (isStringType!T) return "QString"; + else static if (isQList!T) + return "QList<" ~ qtDeclArg!(templateParam!T)() ~ ">"; else static if (isNativeType!T) return Unqual!T.stringof; else