Преобразовать индексную функцию из Objective C в Swift - PullRequest
0 голосов
/ 20 марта 2020

Я пытаюсь преобразовать некоторый код Objective C в Swift и не могу сделать это правильно с помощью подписки. Это метод, который я пытаюсь перенести в Swift:

- (NSArray *)rangesOfSubstringAlphaNumeric:(NSString *)substring rangesLimit:(NSUInteger)rangesLimit {
    NSAssert(rangesLimit, @"A range limit grather than 0 must be specified");
    if (!substring.length) {
        return nil;
    }
    static NSCharacterSet * restrictedCharacters = nil;
    if (!restrictedCharacters) {
        restrictedCharacters = [[NSCharacterSet alphanumericCharacterSet] invertedSet];
    }
    NSArray * substrings = [substring componentsSeparatedByCharactersInSet:restrictedCharacters];
    NSMutableArray * allRanges = [NSMutableArray array];
    NSString *searchedString = self;
    for (NSString *stringToMatch in substrings) {
        if (![stringToMatch isEqualToString:@""]) {
            NSRange aRange;
            NSUInteger lastLocation = 0;
            NSUInteger foundRanges = 0;
            while (foundRanges++ < rangesLimit &&
                   (aRange = [searchedString localizedStandardRangeOfString:stringToMatch]).location != NSNotFound) {
                searchedString = [searchedString substringFromIndex:aRange.location + aRange.length];
                aRange.location = aRange.location + lastLocation;
                lastLocation = aRange.location + aRange.length;
                [allRanges addObject:[NSValue valueWithRange:aRange]];
            }
        }
    }
    return allRanges.count ? [allRanges copy] : nil;
}

Я застрял в подписывающей части, так как кажется, что я не могу присвоить целочисленные значения индексам, и преобразование из Index в Int мне не подходит Я как бы застрял, вот что мне удалось сделать:

func rangesOfAlphanumeric(substring: String, limit: UInt) -> [Range<String.Index>] {
        guard limit > 0, !substring.isEmpty else {
            if limit == 0 {
                assert(false, "limit must be greather than 0")
            }
            return []
        }
        var searchedString = self
        let substrings = substring.components(separatedBy: NSCharacterSet.restricted)
        for stringToMatch in substrings {
            if !stringToMatch.isEmpty {

//                var aRange: Range<String.Index>?
//                var lastLocation: UInt = 0
//                var foundRanges: UInt = 0

//                while foundRanges < limit,
//                    let tempRange = searchedString.localizedStandardRange(of: stringToMatch),
//                    !tempRange.isEmpty {
//
//                        searchedString = String(searchedString[tempRange.upperBound...])
//                        if let lastLocation = lastLocation {
//                            aRange = temp
//                        }
//                }

            }
        }
    }

ОБНОВЛЕНИЕ: Решение ниже.

Ответы [ 2 ]

0 голосов
/ 22 марта 2020

удалось решить проблему с помощью функции ranges, размещенной здесь :

func rangesOfAlphanumeric(substring: String) -> [Range<String.Index>] {
    var searchedString = self
    let substrings = substring.components(separatedBy: NSCharacterSet.restricted)
    return substrings.compactMap { (stringToMatch) -> [Range<String.Index>]? in
        guard !stringToMatch.isEmpty else {
            return nil
        }
        let ranges = searchedString.ranges(of: stringToMatch, options: [
            .diacriticInsensitive,
            .caseInsensitive
        ])

        if let lastRange = ranges.last {
            searchedString = String(searchedString[index(after: lastRange.upperBound)])
        }
        return ranges
    }.flatMap{$0}
}
0 голосов
/ 20 марта 2020

Я создал этот репозиторий с swift 5, он очень прост в использовании, все уже настроено. Вы просто должны изменить IAP идентификаторы

Репозиторий Github

...