Неверный параметр не соответствует требованиям: messageSenderId != nil

Я интегрировал 'XBChatModule' библиотеку от Cocoapods в свой проект.

Когда я запускаю код в первый раз, он приводит к сбою приложения, выдавая следующую ошибку -[XBMessage messageHash]: нераспознанный селектор отправлен в экземпляр и это было решено путем изменения файла XBMessage.m, как показано ниже.

XBMessage.m

- (NSUInteger)messageHash
{
    return self.hash;
}

Но это создает новую проблему, говорящую

Assertion failure in -[ChatMessagesController collectionView:cellForItemAtIndexPath:], /Users/Neelacharya/Harshit/LIve Projects/Project/V1/Source/Project/Pods/JSQMessagesViewController/JSQMessagesViewController/Controllers/JSQMessagesViewController.m:452

Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Invalid parameter not satisfying: messageSenderId != nil'

*** First throw call stack:
(
    0   CoreFoundation                      0x000000011161ca75 __exceptionPreprocess + 165
    1   libobjc.A.dylib                     0x00000001112b1bb7 objc_exception_throw + 45
    2   CoreFoundation                      0x000000011161c8da +[NSException raise:format:arguments:] + 106
    3   Foundation                          0x000000010edcfb6f -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 195
    4   CinchGaming                         0x000000010d7be3c5 -[JSQMessagesViewController collectionView:cellForItemAtIndexPath:] + 693
    5   CinchGaming                         0x000000010d7f5f6d -[XBMessageViewController collectionView:cellForItemAtIndexPath:] + 141
    6   UIKit                               0x00000001102b9fab -[UICollectionView _createPreparedCellForItemAtIndexPath:withLayoutAttributes:applyAttributes:] + 244
    7   UIKit                               0x00000001102bb6e4 -[UICollectionView _updateVisibleCellsNow:] + 3445
    8   UIKit                               0x00000001102bf391 -[UICollectionView layoutSubviews] + 243
    9   UIKit                               0x000000010fd041c3 -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 521
    10  QuartzCore                          0x000000010f9d2c58 -[CALayer layoutSublayers] + 150
    11  QuartzCore                          0x000000010f9c787e _ZN2CA5Layer16layout_if_neededEPNS_11TransactionE + 380
    12  QuartzCore                          0x000000010f9c76ee _ZN2CA5Layer28layout_and_display_if_neededEPNS_11TransactionE + 24
    13  QuartzCore                          0x000000010f93536e _ZN2CA7Context18commit_transactionEPNS_11TransactionE + 242
    14  QuartzCore                          0x000000010f936482 _ZN2CA11Transaction6commitEv + 390
    15  QuartzCore                          0x000000010f936aed _ZN2CA11Transaction17observer_callbackEP19__CFRunLoopObservermPv + 89
    16  CoreFoundation                      0x0000000111551507 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 23
    17  CoreFoundation                      0x0000000111551460 __CFRunLoopDoObservers + 368
    18  CoreFoundation                      0x0000000111547293 __CFRunLoopRun + 1123
    19  CoreFoundation                      0x0000000111546bc6 CFRunLoopRunSpecific + 470
    20  GraphicsServices                    0x0000000112796a58 GSEventRunModal + 161
    21  UIKit                               0x000000010fc8a580 UIApplicationMain + 1282
    22  CinchGaming                         0x000000010d67e463 main + 115
    23  libdyld.dylib                       0x0000000111b4e145 start + 1
    24  ???                                 0x0000000000000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException

Я понимаю, что причиной сбоя является член messageSenderId, равный нулю в 452-й строке файла JSQMessagesViewController.m. Но я не знаю, почему это происходит и как это решить.

Я также сообщил авторам о проблеме на Github, но не смог получить ответ.

Буду признателен, если вы поможете мне решить проблему.


person HarshIT    schedule 02.09.2015    source источник
comment
Итак, messageSenderId == nil. Теперь вам нужно выяснить, что обычно заполняет его. Вам также нужно знать, почему вы должны были предоставить реализацию XBMessage messageHash (найдите автора и спросите его/ее). Однако все это немного широко для stackoverflow.   -  person trojanfoe    schedule 02.09.2015
comment
Что ж, когда я увидел пример кода, это старая версия библиотеки, и ей не нужно реализовывать описанный выше метод, который я сделал, но код из какао-бобов как библиотеки требует реализации метода. Я также отправил проблему автору (github.com/EugeneNguyen/XBChatModule/issues/2), но он не отвечает.   -  person HarshIT    schedule 02.09.2015


Ответы (2)


Он думает, что приложение падает в этой строке:

NSString *messageSenderId = [messageItem senderId];
NSParameterAssert(messageSenderId != nil);

Когда я копался в этом, я обнаружил, что senderId устанавливается из метода loadDataToTable XBMessageViewController. Единственная причина, по которой я могу найти значение для senderId равно нулю, это то, что вы не устанавливаете значения для jidStr и senderId.

Вам потребуется установить jidStr и senderId и XBMessageViewController, где jidStr — получатель, а senderId — самостоятельный пользователь.

Надеюсь это поможет.

person Himanshu A Jadav    schedule 25.09.2015

Вам нужно зарегистрировать свой класс как [self.collectionView registerClass:[UICollectionViewCell class] forCellWithReuseIdentifier:@"Cell"];

person Misha    schedule 02.09.2015
comment
зачем регистрация? родительский класс контроллера представления уже сделал то же самое. - person HarshIT; 02.09.2015
comment
Я думаю, что в ChatMessagesController вы будете повторно использовать ячейку, поэтому либо вы отправляете регистрацию, либо не используете cellIdentifier. - person Misha; 02.09.2015
comment
Я не думаю, что это проблема с Collecitonview или его ячейкой, потому что свойство класса модели равно нулю - person HarshIT; 02.09.2015
comment
Я подумал, что из журнала, возможно, вам следует проверить cellForItemAtIndexPath? - person Misha; 02.09.2015