diff --git a/RNTester/RNTesterUnitTests/RCTMethodArgumentTests.m b/RNTester/RNTesterUnitTests/RCTMethodArgumentTests.m index 79c8db6869b4b2..8c266cdce9a06d 100644 --- a/RNTester/RNTesterUnitTests/RCTMethodArgumentTests.m +++ b/RNTester/RNTesterUnitTests/RCTMethodArgumentTests.m @@ -90,11 +90,12 @@ - (void)testUntypedUnnamedArgs - (void)testNamespacedCxxStruct { NSArray *arguments; - const char *methodSignature = "foo:(foo::type &)foo"; + const char *methodSignature = "foo:(foo::type &)foo bar:(bar::type &)bar"; SEL selector = RCTParseMethodSignature(methodSignature, &arguments); - XCTAssertEqualObjects(NSStringFromSelector(selector), @"foo:"); - XCTAssertEqual(arguments.count, (NSUInteger)1); + XCTAssertEqualObjects(NSStringFromSelector(selector), @"foo:bar:"); + XCTAssertEqual(arguments.count, (NSUInteger)2); XCTAssertEqualObjects(((RCTMethodArgument *)arguments[0]).type, @"foo::type"); + XCTAssertEqualObjects(((RCTMethodArgument *)arguments[1]).type, @"bar::type"); } - (void)testAttributes diff --git a/React/Base/RCTParserUtils.m b/React/Base/RCTParserUtils.m index 138fdf744dc5f3..d70c4181b8e2a8 100644 --- a/React/Base/RCTParserUtils.m +++ b/React/Base/RCTParserUtils.m @@ -136,7 +136,9 @@ static BOOL RCTIsCollectionType(NSString *type) RCTReadChar(input, '>'); } RCTSkipWhitespace(input); - RCTReadChar(input, '*'); + if (!RCTReadChar(input, '*')) { + RCTReadChar(input, '&'); + } return type; }