Working with inline latex parsing
This commit is contained in:
		
							parent
							
								
									ef97b0bc25
								
							
						
					
					
						commit
						a298016ac2
					
				| @ -19,6 +19,8 @@ dependencies { | |||||||
| 
 | 
 | ||||||
|     api deps['jlatexmath-android'] |     api deps['jlatexmath-android'] | ||||||
| 
 | 
 | ||||||
|  |     debugImplementation project(':markwon-inline-parser') | ||||||
|  | 
 | ||||||
|     deps['test'].with { |     deps['test'].with { | ||||||
|         testImplementation it['junit'] |         testImplementation it['junit'] | ||||||
|         testImplementation it['robolectric'] |         testImplementation it['robolectric'] | ||||||
|  | |||||||
| @ -60,6 +60,8 @@ public class JLatexMathBlockParser extends AbstractBlockParser { | |||||||
|         @Override |         @Override | ||||||
|         public BlockStart tryStart(ParserState state, MatchedBlockParser matchedBlockParser) { |         public BlockStart tryStart(ParserState state, MatchedBlockParser matchedBlockParser) { | ||||||
| 
 | 
 | ||||||
|  |             // ^\s{0,3}\$\$\s*$ as a regex to star the block | ||||||
|  | 
 | ||||||
|             final CharSequence line = state.getLine(); |             final CharSequence line = state.getLine(); | ||||||
|             final int length = line != null |             final int length = line != null | ||||||
|                     ? line.length() |                     ? line.length() | ||||||
|  | |||||||
| @ -0,0 +1,19 @@ | |||||||
|  | package io.noties.markwon.ext.latex; | ||||||
|  | 
 | ||||||
|  | import org.commonmark.node.CustomNode; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * @since 4.2.1-SNAPSHOT | ||||||
|  |  */ | ||||||
|  | public class JLatexMathInline extends CustomNode { | ||||||
|  | 
 | ||||||
|  |     private String latex; | ||||||
|  | 
 | ||||||
|  |     public String latex() { | ||||||
|  |         return latex; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void latex(String latex) { | ||||||
|  |         this.latex = latex; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -14,6 +14,8 @@ import androidx.annotation.Nullable; | |||||||
| import androidx.annotation.Px; | import androidx.annotation.Px; | ||||||
| import androidx.annotation.VisibleForTesting; | import androidx.annotation.VisibleForTesting; | ||||||
| 
 | 
 | ||||||
|  | import org.commonmark.node.Node; | ||||||
|  | import org.commonmark.parser.InlineParserFactory; | ||||||
| import org.commonmark.parser.Parser; | import org.commonmark.parser.Parser; | ||||||
| 
 | 
 | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
| @ -30,6 +32,9 @@ import io.noties.markwon.image.AsyncDrawableLoader; | |||||||
| import io.noties.markwon.image.AsyncDrawableScheduler; | import io.noties.markwon.image.AsyncDrawableScheduler; | ||||||
| import io.noties.markwon.image.AsyncDrawableSpan; | import io.noties.markwon.image.AsyncDrawableSpan; | ||||||
| import io.noties.markwon.image.ImageSizeResolver; | import io.noties.markwon.image.ImageSizeResolver; | ||||||
|  | import io.noties.markwon.image.ImageSizeResolverDef; | ||||||
|  | import io.noties.markwon.inlineparser.InlineProcessor; | ||||||
|  | import io.noties.markwon.inlineparser.MarkwonInlineParser; | ||||||
| import ru.noties.jlatexmath.JLatexMathDrawable; | import ru.noties.jlatexmath.JLatexMathDrawable; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
| @ -120,7 +125,17 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin { | |||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void configureParser(@NonNull Parser.Builder builder) { |     public void configureParser(@NonNull Parser.Builder builder) { | ||||||
|         builder.customBlockParserFactory(new JLatexMathBlockParser.Factory()); | 
 | ||||||
|  |         // what we can do: | ||||||
|  |         // [0-3] spaces before block start/end | ||||||
|  |         // if it's $$\n -> block | ||||||
|  |         // if it's $$\\dhdsfjh$$ -> inline | ||||||
|  | 
 | ||||||
|  | //        builder.customBlockParserFactory(new JLatexMathBlockParser.Factory()); | ||||||
|  |         final InlineParserFactory factory = MarkwonInlineParser.factoryBuilderNoDefaults() | ||||||
|  |                 .addInlineProcessor(new LatexInlineProcessor()) | ||||||
|  |                 .build(); | ||||||
|  |         builder.inlineParserFactory(factory); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
| @ -145,9 +160,9 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin { | |||||||
|                         new AsyncDrawable( |                         new AsyncDrawable( | ||||||
|                                 latex, |                                 latex, | ||||||
|                                 jLatextAsyncDrawableLoader, |                                 jLatextAsyncDrawableLoader, | ||||||
|                                 jLatexImageSizeResolver, |                                 new ImageSizeResolverDef(), | ||||||
|                                 null), |                                 null), | ||||||
|                         AsyncDrawableSpan.ALIGN_BOTTOM, |                         AsyncDrawableSpan.ALIGN_CENTER, | ||||||
|                         false); |                         false); | ||||||
| 
 | 
 | ||||||
|                 visitor.setSpans(length, span); |                 visitor.setSpans(length, span); | ||||||
| @ -155,6 +170,77 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin { | |||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     private static class LatexInlineProcessor extends InlineProcessor { | ||||||
|  | 
 | ||||||
|  |         @Override | ||||||
|  |         public char specialCharacter() { | ||||||
|  |             return '$'; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         @Nullable | ||||||
|  |         @Override | ||||||
|  |         protected Node parse() { | ||||||
|  | 
 | ||||||
|  |             final int start = index; | ||||||
|  | 
 | ||||||
|  |             index += 1; | ||||||
|  |             if (peek() != '$') { | ||||||
|  |                 index = start; | ||||||
|  |                 return null; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             // must be not $ | ||||||
|  |             index += 1; | ||||||
|  |             if (peek() == '$') { | ||||||
|  |                 return text("$"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             // find next '$$', but not broken with 2(or more) new lines | ||||||
|  | 
 | ||||||
|  |             boolean dollar = false; | ||||||
|  |             boolean newLine = false; | ||||||
|  |             boolean found = false; | ||||||
|  | 
 | ||||||
|  |             index += 1; | ||||||
|  |             final int length = input.length(); | ||||||
|  | 
 | ||||||
|  |             while (index < length) { | ||||||
|  |                 final char c = peek(); | ||||||
|  |                 if (c == '\n') { | ||||||
|  |                     if (newLine) { | ||||||
|  |                         // second new line | ||||||
|  |                         break; | ||||||
|  |                     } | ||||||
|  |                     newLine = true; | ||||||
|  |                     dollar = false; // cannot be on another line | ||||||
|  |                 } else { | ||||||
|  |                     newLine = false; | ||||||
|  |                     if (c == '$') { | ||||||
|  |                         if (dollar) { | ||||||
|  |                             found = true; | ||||||
|  |                             // advance | ||||||
|  |                             index += 1; | ||||||
|  |                             break; | ||||||
|  |                         } | ||||||
|  |                         dollar = true; | ||||||
|  |                     } else { | ||||||
|  |                         dollar = false; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 index += 1; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (found) { | ||||||
|  |                 final JLatexMathBlock block = new JLatexMathBlock(); | ||||||
|  |                 block.latex(input.substring(start + 2, index - 2)); | ||||||
|  |                 index += 1; | ||||||
|  |                 return block; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void beforeSetText(@NonNull TextView textView, @NonNull Spanned markdown) { |     public void beforeSetText(@NonNull TextView textView, @NonNull Spanned markdown) { | ||||||
|         AsyncDrawableScheduler.unschedule(textView); |         AsyncDrawableScheduler.unschedule(textView); | ||||||
| @ -182,7 +268,7 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin { | |||||||
|         @JLatexMathDrawable.Align |         @JLatexMathDrawable.Align | ||||||
|         private int align = JLatexMathDrawable.ALIGN_CENTER; |         private int align = JLatexMathDrawable.ALIGN_CENTER; | ||||||
| 
 | 
 | ||||||
|         private boolean fitCanvas = true; |         private boolean fitCanvas = false; | ||||||
| 
 | 
 | ||||||
|         // @since 4.0.0 |         // @since 4.0.0 | ||||||
|         private int paddingHorizontal; |         private int paddingHorizontal; | ||||||
|  | |||||||
| @ -49,6 +49,7 @@ dependencies { | |||||||
|     implementation project(':markwon-syntax-highlight') |     implementation project(':markwon-syntax-highlight') | ||||||
| 
 | 
 | ||||||
|     implementation project(':markwon-image-picasso') |     implementation project(':markwon-image-picasso') | ||||||
|  |     implementation project(':markwon-image-glide') | ||||||
| 
 | 
 | ||||||
|     deps.with { |     deps.with { | ||||||
|         implementation it['x-recycler-view'] |         implementation it['x-recycler-view'] | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dimitry Ivanov
						Dimitry Ivanov