From efa011d7beaec88d5d8b42c6fa222f4c23786d94 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Herv=C3=A9=20Guillemet?= Date: Sat, 20 Jan 2024 11:25:39 +0100 Subject: [PATCH 1/2] Ensure constructor cppName is class name --- .../org/bytedeco/javacpp/tools/Parser.java | 20 ++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/src/main/java/org/bytedeco/javacpp/tools/Parser.java b/src/main/java/org/bytedeco/javacpp/tools/Parser.java index d5381fc0..04a5ff7b 100644 --- a/src/main/java/org/bytedeco/javacpp/tools/Parser.java +++ b/src/main/java/org/bytedeco/javacpp/tools/Parser.java @@ -136,7 +136,7 @@ static String upcastMethodName(String javaName) { * NS::CN::CN(int) * Declarator.cppName contains the calling name, and this method returns the declaration name. * Keys in info map should use the declaration name, because the calling name cannot specify - * arguments in case of constructor templates, and to avoid confusion between classes and constructores info. + * arguments in case of constructor templates, and to avoid confusion between classes and constructors info. */ static String constructorName(String cppName) { String constructorName = Templates.strip(cppName); @@ -1161,6 +1161,7 @@ else if (cppNameSplit.size() > 1 && groupNameSplit.size() == 1) if (cppName.equals(groupName)) { type.constructor = !type.destructor && !type.operator && type.indirections == 0 && !type.reference && tokens.get().match('(', ':'); + if (type.constructor) type.cppName = context.cppName; // Fix potential qualification errors } type.javaName = context.shorten(type.javaName); } @@ -2593,17 +2594,18 @@ boolean function(Context context, DeclarationList declList) throws ParserExcepti if (context.namespace != null && !isQualified) { dcl.cppName = context.namespace + "::" + dcl.cppName; } - } - // use Java names that we may get here but that declarator() did not catch - for (String name : context.qualify(dcl.cppName, param1)) { - if ((infoMap.getFirst(name, false)) != null) { - dcl.cppName = name; - break; - } else if (infoMap.getFirst(name) != null) { - dcl.cppName = name; + // use Java names that we may get here but that declarator() did not catch + for (String name : context.qualify(dcl.cppName, param1)) { + if ((infoMap.getFirst(name, false)) != null) { + dcl.cppName = name; + break; + } else if (infoMap.getFirst(name) != null) { + dcl.cppName = name; + } } } + String localName2 = dcl.cppName; if (context.namespace != null && localName2.startsWith(context.namespace + "::")) { localName2 = dcl.cppName.substring(context.namespace.length() + 2); From bea6f0694514933724fed761a0a550d7d1ea78d4 Mon Sep 17 00:00:00 2001 From: Samuel Audet Date: Mon, 22 Jan 2024 17:24:42 +0900 Subject: [PATCH 2/2] Update CHANGELOG.md --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 74dd8098..e9de5b88 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,4 +1,5 @@ + * Fix `Parser` failing to pick up `Info` for constructors with template arguments ([pull #739](https://github.com/bytedeco/javacpp/pull/739)) * Fix `MoveAdapter` and `UniquePtrAdapter` causing double free on function calls ([pull #738](https://github.com/bytedeco/javacpp/pull/738)) * Fix `Parser` handling of `template` specialization and their `friend` declarations ([pull #733](https://github.com/bytedeco/javacpp/pull/733)) * Improve `Parser` capabilities for `operator` and function templates ([pull #732](https://github.com/bytedeco/javacpp/pull/732))