summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEmilio Cobos Álvarez <emilio@crisal.io>2017-05-10 14:03:10 +0200
committerEmilio Cobos Álvarez <emilio@crisal.io>2017-05-10 14:03:10 +0200
commit17d00ded517f06904dfd1eed2ff51f8b4b90f895 (patch)
tree59c1a8215e194f114c3847247d41141dee350de2
parent31e440917cdc8ac57cd69ddf929e90a7c4b46367 (diff)
ir: Handle default template parameters in libclang >3.9.
Fixes #585
-rw-r--r--src/ir/template.rs21
1 files changed, 16 insertions, 5 deletions
diff --git a/src/ir/template.rs b/src/ir/template.rs
index 5861929f..5c570996 100644
--- a/src/ir/template.rs
+++ b/src/ir/template.rs
@@ -233,11 +233,22 @@ impl TemplateInstantiation {
let template_args = ty.template_args()
.map_or(vec![], |args| {
- args.filter(|t| t.kind() != CXType_Invalid)
- .map(|t| {
- Item::from_ty_or_ref(t, t.declaration(), None, ctx)
- })
- .collect()
+ match ty.canonical_type().template_args() {
+ Some(canonical_args) => {
+ let arg_count = args.len();
+ args.chain(canonical_args.skip(arg_count))
+ .filter(|t| t.kind() != CXType_Invalid)
+ .map(|t| {
+ Item::from_ty_or_ref(t, t.declaration(), None, ctx)
+ }).collect()
+ }
+ None => {
+ args.filter(|t| t.kind() != CXType_Invalid)
+ .map(|t| {
+ Item::from_ty_or_ref(t, t.declaration(), None, ctx)
+ }).collect()
+ }
+ }
});
let definition = ty.declaration()