From 850b78e93895128962f621cd6871520eb333dccd Mon Sep 17 00:00:00 2001 From: Stephen Williams Date: Fri, 6 Jul 2018 22:29:45 +1200 Subject: [PATCH 1/3] Fix the emphisis in a heading and depink code --- TSMarkdownParser/TSMarkdownParser.m | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/TSMarkdownParser/TSMarkdownParser.m b/TSMarkdownParser/TSMarkdownParser.m index c48090c..eab4639 100644 --- a/TSMarkdownParser/TSMarkdownParser.m +++ b/TSMarkdownParser/TSMarkdownParser.m @@ -74,9 +74,9 @@ - (instancetype)init { // Courier New and Courier are the only monospace fonts compatible with watchOS 2 // #69: avoiding crash if font is missing _monospaceAttributes = @{ NSFontAttributeName: [UIFont fontWithName:@"Courier New" size:defaultSize] ?: [UIFont fontWithName:@"Courier" size:defaultSize] ?: [UIFont systemFontOfSize:defaultSize], - NSForegroundColorAttributeName: [UIColor colorWithSRGBRed:0.95 green:0.54 blue:0.55 alpha:1] }; + NSForegroundColorAttributeName: [UIColor blackColor] }; _strongAttributes = @{ NSFontAttributeName: [UIFont boldSystemFontOfSize:defaultSize] }; - + return self; } @@ -93,12 +93,6 @@ + (instancetype)standardParser { /* block parsing */ - [defaultParser addHeaderParsingWithMaxLevel:0 leadFormattingBlock:^(NSMutableAttributedString *attributedString, NSRange range, __unused NSUInteger level) { - [attributedString deleteCharactersInRange:range]; - } textFormattingBlock:^(NSMutableAttributedString *attributedString, NSRange range, NSUInteger level) { - [TSMarkdownParser addAttributes:weakParser.headerAttributes atIndex:level - 1 toString:attributedString range:range]; - }]; - [defaultParser addListParsingWithMaxLevel:0 leadFormattingBlock:^(NSMutableAttributedString *attributedString, NSRange range, NSUInteger level) { NSMutableString *listString = [NSMutableString string]; while (--level) @@ -204,10 +198,22 @@ + (instancetype)standardParser { [attributedString addAttributes:weakParser.strongAttributes range:range]; }]; + [defaultParser addStrikethroughParsingWithFormattingBlock:^(NSMutableAttributedString *attributedString, NSRange range) { + [attributedString addAttribute:NSStrikethroughStyleAttributeName + value:@2 + range:range]; + }]; + [defaultParser addEmphasisParsingWithFormattingBlock:^(NSMutableAttributedString *attributedString, NSRange range) { [attributedString addAttributes:weakParser.emphasisAttributes range:range]; }]; + [defaultParser addHeaderParsingWithMaxLevel:0 leadFormattingBlock:^(NSMutableAttributedString *attributedString, NSRange range, __unused NSUInteger level) { + [attributedString deleteCharactersInRange:range]; + } textFormattingBlock:^(NSMutableAttributedString *attributedString, NSRange range, NSUInteger level) { + [TSMarkdownParser addAttributes:weakParser.headerAttributes atIndex:level - 1 toString:attributedString range:range]; + }]; + /* unescaping parsing */ [defaultParser addCodeUnescapingParsingWithFormattingBlock:^(NSMutableAttributedString *attributedString, NSRange range) { @@ -248,6 +254,7 @@ + (void)addAttributes:(NSArray *> *)attributesArray // inline enclosed regex static NSString *const TSMarkdownMonospaceRegex = @"(`+)(\\s*.*?[^`]\\s*)(\\1)(?!`)"; static NSString *const TSMarkdownStrongRegex = @"(\\*\\*|__)(.+?)(\\1)"; +static NSString *const TSMarkdownStikethroughRegex = @"(\\~\\~|__)(.+?)(\\1)"; static NSString *const TSMarkdownEmRegex = @"(\\*|_)(.+?)(\\1)"; #pragma mark escaping parsing @@ -449,6 +456,10 @@ - (void)addStrongParsingWithFormattingBlock:(void(^)(NSMutableAttributedString * [self addEnclosedParsingWithPattern:TSMarkdownStrongRegex formattingBlock:formattingBlock]; } +- (void)addStrikethroughParsingWithFormattingBlock:(void(^)(NSMutableAttributedString *attributedString, NSRange range))formattingBlock { + [self addEnclosedParsingWithPattern:TSMarkdownStikethroughRegex formattingBlock:formattingBlock]; +} + - (void)addEmphasisParsingWithFormattingBlock:(TSMarkdownParserFormattingBlock)formattingBlock { [self addEnclosedParsingWithPattern:TSMarkdownEmRegex formattingBlock:formattingBlock]; } From 371558baea7f60c8edf269f7a02a364942853c9d Mon Sep 17 00:00:00 2001 From: Stephen Williams Date: Fri, 7 Dec 2018 10:41:44 +1300 Subject: [PATCH 2/3] Render nested lists --- TSMarkdownParser/TSMarkdownParser.m | 2 +- TSMarkdownParserTests/TSMarkdownParserTests.m | 5 +++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/TSMarkdownParser/TSMarkdownParser.m b/TSMarkdownParser/TSMarkdownParser.m index eab4639..69120b2 100644 --- a/TSMarkdownParser/TSMarkdownParser.m +++ b/TSMarkdownParser/TSMarkdownParser.m @@ -242,7 +242,7 @@ + (void)addAttributes:(NSArray *> *)attributesArray // lead regex static NSString *const TSMarkdownHeaderRegex = @"^(#{1,%@})\\s+(.+)$"; static NSString *const TSMarkdownShortHeaderRegex = @"^(#{1,%@})\\s*([^#].*)$"; -static NSString *const TSMarkdownListRegex = @"^([\\*\\+\\-]{1,%@})\\s+(.+)$"; +static NSString *const TSMarkdownListRegex = @"^([\\h]*[\\*\\+\\-]{1,%@})\\s+(.+)$"; static NSString *const TSMarkdownShortListRegex = @"^([\\*\\+\\-]{1,%@})\\s*([^\\*\\+\\-].*)$"; static NSString *const TSMarkdownQuoteRegex = @"^(\\>{1,%@})\\s+(.+)$"; static NSString *const TSMarkdownShortQuoteRegex = @"^(\\>{1,%@})\\s*([^\\>].*)$"; diff --git a/TSMarkdownParserTests/TSMarkdownParserTests.m b/TSMarkdownParserTests/TSMarkdownParserTests.m index 1ede679..8639a89 100644 --- a/TSMarkdownParserTests/TSMarkdownParserTests.m +++ b/TSMarkdownParserTests/TSMarkdownParserTests.m @@ -200,6 +200,11 @@ - (void)testStandardListWith2AsterisksParsing { XCTAssertEqualObjects(attributedString.string, @"Hello\n\t•\tI drink in a café everyday\nto use Wi-Fi"); } +- (void)testNestedList { + NSAttributedString *attributedString = [self.standardParser attributedStringFromMarkdown:@"\n\n- 1\n - 1.1\n- 2"]; + XCTAssertEqualObjects(attributedString.string, @"\n\n•\t1\n\t\t•\t1.1\n•\t2"); +} + - (void)testStandardQuoteParsing { NSAttributedString *attributedString = [self.standardParser attributedStringFromMarkdown:@"Hello\n> I drink in a café everyday\nto use Wi-Fi"]; XCTAssertEqualObjects(attributedString.string, @"Hello\n\tI drink in a café everyday\nto use Wi-Fi"); From 8634b67e4bc6356214dc5793780a96296267d32a Mon Sep 17 00:00:00 2001 From: Stephen Williams Date: Fri, 7 Dec 2018 10:57:05 +1300 Subject: [PATCH 3/3] Add a test for the strikethrough rendering --- TSMarkdownParserTests/TSMarkdownParserTests.m | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/TSMarkdownParserTests/TSMarkdownParserTests.m b/TSMarkdownParserTests/TSMarkdownParserTests.m index 8639a89..4120e42 100644 --- a/TSMarkdownParserTests/TSMarkdownParserTests.m +++ b/TSMarkdownParserTests/TSMarkdownParserTests.m @@ -205,6 +205,13 @@ - (void)testNestedList { XCTAssertEqualObjects(attributedString.string, @"\n\n•\t1\n\t\t•\t1.1\n•\t2"); } +- (void)testStrikethroughParsing { + NSAttributedString *attributedString = [self.standardParser attributedStringFromMarkdown:@"~~Hello~~"]; + NSNumber *strikethrough = [attributedString attribute:NSStrikethroughStyleAttributeName atIndex:2 effectiveRange:NULL]; + XCTAssertNotNil(strikethrough); + XCTAssertEqualObjects(attributedString.string, @"Hello"); +} + - (void)testStandardQuoteParsing { NSAttributedString *attributedString = [self.standardParser attributedStringFromMarkdown:@"Hello\n> I drink in a café everyday\nto use Wi-Fi"]; XCTAssertEqualObjects(attributedString.string, @"Hello\n\tI drink in a café everyday\nto use Wi-Fi");