| Index: third_party/ocmock/OCMock/OCProtocolMockObject.m
|
| diff --git a/third_party/ocmock/OCMock/OCProtocolMockObject.m b/third_party/ocmock/OCMock/OCProtocolMockObject.m
|
| old mode 100644
|
| new mode 100755
|
| index 19e25e8796801126d4bb61b8dffbd86a168ee73c..82f61679f68abd25b186d1450a3dbd27a6602ab5
|
| --- a/third_party/ocmock/OCMock/OCProtocolMockObject.m
|
| +++ b/third_party/ocmock/OCMock/OCProtocolMockObject.m
|
| @@ -1,7 +1,18 @@
|
| -//---------------------------------------------------------------------------------------
|
| -// $Id$
|
| -// Copyright (c) 2005-2008 by Mulle Kybernetik. See License file for details.
|
| -//---------------------------------------------------------------------------------------
|
| +/*
|
| + * Copyright (c) 2005-2015 Erik Doernenburg and contributors
|
| + *
|
| + * Licensed under the Apache License, Version 2.0 (the "License"); you may
|
| + * not use these files except in compliance with the License. You may obtain
|
| + * a copy of the License at
|
| + *
|
| + * http://www.apache.org/licenses/LICENSE-2.0
|
| + *
|
| + * Unless required by applicable law or agreed to in writing, software
|
| + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
| + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
| + * License for the specific language governing permissions and limitations
|
| + * under the License.
|
| + */
|
|
|
| #import <objc/runtime.h>
|
| #import "NSMethodSignature+OCMAdditions.h"
|
| @@ -13,6 +24,7 @@
|
|
|
| - (id)initWithProtocol:(Protocol *)aProtocol
|
| {
|
| + NSParameterAssert(aProtocol != nil);
|
| [super init];
|
| mockedProtocol = aProtocol;
|
| return self;
|
| @@ -21,23 +33,21 @@
|
| - (NSString *)description
|
| {
|
| const char* name = protocol_getName(mockedProtocol);
|
| - return [NSString stringWithFormat:@"OCMockObject[%s]", name];
|
| + return [NSString stringWithFormat:@"OCMockObject(%s)", name];
|
| }
|
|
|
| #pragma mark Proxy API
|
|
|
| - (NSMethodSignature *)methodSignatureForSelector:(SEL)aSelector
|
| {
|
| - struct objc_method_description methodDescription = protocol_getMethodDescription(mockedProtocol, aSelector, YES, YES);
|
| - if(methodDescription.name == NULL)
|
| - {
|
| - methodDescription = protocol_getMethodDescription(mockedProtocol, aSelector, NO, YES);
|
| + struct { BOOL isRequired; BOOL isInstance; } opts[4] = { {YES, YES}, {NO, YES}, {YES, NO}, {NO, NO} };
|
| + for(int i = 0; i < 4; i++)
|
| + {
|
| + struct objc_method_description methodDescription = protocol_getMethodDescription(mockedProtocol, aSelector, opts[i].isRequired, opts[i].isInstance);
|
| + if(methodDescription.name != NULL)
|
| + return [NSMethodSignature signatureWithObjCTypes:methodDescription.types];
|
| }
|
| - if(methodDescription.name == NULL)
|
| - {
|
| - return nil;
|
| - }
|
| - return [NSMethodSignature signatureWithObjCTypes:methodDescription.types];
|
| + return nil;
|
| }
|
|
|
| - (BOOL)conformsToProtocol:(Protocol *)aProtocol
|
|
|