From f9339292c4971b6fca0ae1a18fb48a9d39d20464 Mon Sep 17 00:00:00 2001 From: Liam Date: Thu, 21 Nov 2024 09:41:39 -0500 Subject: [PATCH 1/2] Remove old subscript support --- lib/philomena/markdown.ex | 14 ---- lib/philomena/markdown/subscript_migrator.ex | 82 -------------------- lib/philomena/native.ex | 6 -- lib/philomena/release.ex | 4 - native/philomena/src/lib.rs | 15 +--- native/philomena/src/markdown.rs | 37 +-------- native/philomena/src/tests.rs | 2 +- 7 files changed, 5 insertions(+), 155 deletions(-) delete mode 100644 lib/philomena/markdown/subscript_migrator.ex diff --git a/lib/philomena/markdown.ex b/lib/philomena/markdown.ex index 6a361c2a6..be3d426b6 100644 --- a/lib/philomena/markdown.ex +++ b/lib/philomena/markdown.ex @@ -17,20 +17,6 @@ defmodule Philomena.Markdown do def to_html_unsafe(text, replacements), do: Philomena.Native.markdown_to_html_unsafe(text, replacements) - @doc """ - Places a Markdown document into its canonical CommonMark form. - """ - @spec to_cm(String.t()) :: String.t() - def to_cm(text), - do: Philomena.Native.markdown_to_cm(text) - - @doc """ - Determines whether a Markdown document uses a subscript operator, for migration. - """ - @spec has_subscript?(String.t()) :: boolean() - def has_subscript?(text), - do: Philomena.Native.markdown_has_subscript(text) - @doc """ Escapes special characters in text which is to be rendered as Markdown. """ diff --git a/lib/philomena/markdown/subscript_migrator.ex b/lib/philomena/markdown/subscript_migrator.ex deleted file mode 100644 index 36d51176d..000000000 --- a/lib/philomena/markdown/subscript_migrator.ex +++ /dev/null @@ -1,82 +0,0 @@ -defmodule Philomena.Markdown.SubscriptMigrator do - alias Philomena.Comments.Comment - alias Philomena.Commissions.Item, as: CommissionItem - alias Philomena.Commissions.Commission - alias Philomena.DnpEntries.DnpEntry - alias Philomena.Images.Image - alias Philomena.Conversations.Message - alias Philomena.ModNotes.ModNote - alias Philomena.Posts.Post - alias Philomena.Reports.Report - alias Philomena.Tags.Tag - alias Philomena.Users.User - - import Ecto.Query - alias PhilomenaQuery.Batch - alias Philomena.Markdown - alias Philomena.Repo - - @types %{ - comments: {Comment, [:body]}, - commission_items: {CommissionItem, [:description, :add_ons]}, - commissions: {Commission, [:information, :contact, :will_create, :will_not_create]}, - dnp_entries: {DnpEntry, [:conditions, :reason, :instructions]}, - images: {Image, [:description, :scratchpad]}, - messages: {Message, [:body]}, - mod_notes: {ModNote, [:body]}, - posts: {Post, [:body]}, - reports: {Report, [:reason]}, - tags: {Tag, [:description]}, - users: {User, [:description, :scratchpad]} - } - - @doc """ - Format the ranged Markdown documents to their canonical CommonMark form. - """ - @spec migrate(type :: :all | atom(), id_start :: non_neg_integer(), id_end :: non_neg_integer()) :: - :ok - def migrate(type, id_start, id_end) - - def migrate(:all, _id_start, _id_end) do - Enum.each(@types, fn {name, _schema_columns} -> - migrate(name, 0, 2_147_483_647) - end) - end - - def migrate(type, id_start, id_end) do - IO.puts("#{type}:") - - {schema, columns} = Map.fetch!(@types, type) - - schema - |> where([s], s.id >= ^id_start and s.id < ^id_end) - |> Batch.records() - |> Enum.each(fn s -> - case generate_updates(s, columns) do - [] -> - :ok - - updates -> - IO.write("\r#{s.id}") - - {1, nil} = - schema - |> where(id: ^s.id) - |> Repo.update_all(set: updates) - end - end) - end - - @spec generate_updates(s :: struct(), columns :: [atom()]) :: Keyword.t() - defp generate_updates(s, columns) do - Enum.flat_map(columns, fn col -> - with value when not is_nil(value) <- Map.fetch!(s, col), - true <- Markdown.has_subscript?(value) do - [{col, Markdown.to_cm(value)}] - else - _ -> - [] - end - end) - end -end diff --git a/lib/philomena/native.ex b/lib/philomena/native.ex index 42b80c6df..14eeaa17f 100644 --- a/lib/philomena/native.ex +++ b/lib/philomena/native.ex @@ -9,12 +9,6 @@ defmodule Philomena.Native do @spec markdown_to_html_unsafe(String.t(), %{String.t() => String.t()}) :: String.t() def markdown_to_html_unsafe(_text, _replacements), do: :erlang.nif_error(:nif_not_loaded) - @spec markdown_to_cm(String.t()) :: String.t() - def markdown_to_cm(_text), do: :erlang.nif_error(:nif_not_loaded) - - @spec markdown_has_subscript(String.t()) :: boolean() - def markdown_has_subscript(_text), do: :erlang.nif_error(:nif_not_loaded) - @spec camo_image_url(String.t()) :: String.t() def camo_image_url(_uri), do: :erlang.nif_error(:nif_not_loaded) diff --git a/lib/philomena/release.ex b/lib/philomena/release.ex index 429027cd4..32e24263d 100644 --- a/lib/philomena/release.ex +++ b/lib/philomena/release.ex @@ -14,10 +14,6 @@ defmodule Philomena.Release do {:ok, _, _} = Ecto.Migrator.with_repo(repo, &Ecto.Migrator.run(&1, :down, to: version)) end - def migrate_markdown(type, id_start, id_end) do - Philomena.Markdown.SubscriptMigrator.migrate(type, id_start, id_end) - end - def update_channels do start_app() Philomena.Channels.update_tracked_channels!() diff --git a/native/philomena/src/lib.rs b/native/philomena/src/lib.rs index 9f2beb5b7..ccca12a04 100644 --- a/native/philomena/src/lib.rs +++ b/native/philomena/src/lib.rs @@ -15,9 +15,8 @@ static GLOBAL: Jemalloc = Jemalloc; rustler::init! { "Elixir.Philomena.Native", [ - markdown_to_html, markdown_to_html_unsafe, markdown_to_cm, - markdown_has_subscript, camo_image_url, zip_open_writer, - zip_start_file, zip_write, zip_finish + markdown_to_html, markdown_to_html_unsafe, camo_image_url, + zip_open_writer, zip_start_file, zip_write, zip_finish ], load = load } @@ -40,16 +39,6 @@ fn markdown_to_html_unsafe(input: &str, reps: HashMap) -> String markdown::to_html_unsafe(input, reps) } -#[rustler::nif(schedule = "DirtyCpu")] -fn markdown_to_cm(input: &str) -> String { - markdown::to_cm(input) -} - -#[rustler::nif(schedule = "DirtyCpu")] -fn markdown_has_subscript(input: &str) -> bool { - markdown::has_subscript(input) -} - // Camo NIF wrappers. #[rustler::nif] diff --git a/native/philomena/src/markdown.rs b/native/philomena/src/markdown.rs index 29aa89b29..778deb956 100644 --- a/native/philomena/src/markdown.rs +++ b/native/philomena/src/markdown.rs @@ -1,7 +1,6 @@ use crate::{camo, domains}; -use comrak::nodes::AstNode; -use comrak::{Arena, Options}; -use std::collections::{HashMap, VecDeque}; +use comrak::Options; +use std::collections::HashMap; use std::sync::Arc; pub fn common_options() -> Options { @@ -24,7 +23,6 @@ pub fn common_options() -> Options { options.extension.greentext = true; options.extension.subscript = true; options.extension.philomena = true; - options.extension.alternate_subscript = true; options.render.ignore_empty_links = true; options.render.ignore_setext = true; @@ -54,34 +52,3 @@ pub fn to_html_unsafe(input: &str, reps: HashMap) -> String { comrak::markdown_to_html(input, &options) } - -fn migration_options() -> Options { - let mut options = common_options(); - options.extension.subscript = false; - options -} - -pub fn to_cm(input: &str) -> String { - comrak::markdown_to_commonmark(input, &migration_options()) -} - -pub fn has_subscript(input: &str) -> bool { - let mut queue: VecDeque<&AstNode> = VecDeque::new(); - let arena = Arena::new(); - - queue.push_back(comrak::parse_document(&arena, input, &migration_options())); - - while let Some(front) = queue.pop_front() { - match &front.data.borrow().value { - comrak::nodes::NodeValue::Subscript => return true, - comrak::nodes::NodeValue::Strikethrough => return true, - _ => {} - } - - for child in front.children() { - queue.push_back(child); - } - } - - false -} diff --git a/native/philomena/src/tests.rs b/native/philomena/src/tests.rs index f57eb0f25..39374ceef 100644 --- a/native/philomena/src/tests.rs +++ b/native/philomena/src/tests.rs @@ -45,7 +45,7 @@ fn html_opts_w(input: &str, expected: &str, options: &comrak::Options) { #[test] fn subscript() { - html("H%2%O\n", "
H2O
\n"); + html("H~2~O\n", "
H2O
\n"); } #[test] From e8a67d0a1e69af31597de76bc29d0dc7e510a6c0 Mon Sep 17 00:00:00 2001 From: Liam Date: Thu, 21 Nov 2024 09:46:32 -0500 Subject: [PATCH 2/2] Update comrak version for autolinks --- native/philomena/Cargo.lock | 2 +- native/philomena/Cargo.toml | 2 +- native/philomena/src/tests.rs | 8 ++++++++ 3 files changed, 10 insertions(+), 2 deletions(-) diff --git a/native/philomena/Cargo.lock b/native/philomena/Cargo.lock index 295dc15c4..4ef3513fc 100644 --- a/native/philomena/Cargo.lock +++ b/native/philomena/Cargo.lock @@ -94,7 +94,7 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" [[package]] name = "comrak" version = "0.29.0" -source = "git+https://github.com/philomena-dev/comrak?branch=philomena-0.29.1#85054b19a0383ad9c05aba1add49111c860932dc" +source = "git+https://github.com/philomena-dev/comrak?branch=philomena-0.29.2#00ac2a12d5797feb0ceba9a98487451ab65593fe" dependencies = [ "bon", "caseless", diff --git a/native/philomena/Cargo.toml b/native/philomena/Cargo.toml index de8bab3de..7d8366f16 100644 --- a/native/philomena/Cargo.toml +++ b/native/philomena/Cargo.toml @@ -11,7 +11,7 @@ crate-type = ["dylib"] [dependencies] base64 = "0.21" -comrak = { git = "https://github.com/philomena-dev/comrak", branch = "philomena-0.29.1", default-features = false } +comrak = { git = "https://github.com/philomena-dev/comrak", branch = "philomena-0.29.2", default-features = false } http = "0.2" jemallocator = { version = "0.5.0", features = ["disable_initial_exec_tls"] } regex = "1" diff --git a/native/philomena/src/tests.rs b/native/philomena/src/tests.rs index 39374ceef..84418ed47 100644 --- a/native/philomena/src/tests.rs +++ b/native/philomena/src/tests.rs @@ -56,6 +56,14 @@ fn subscript_autolink_interaction() { ); } +#[test] +fn underscore_autolink_interaction() { + html( + "https://example.com/x_", + "\n" + ) +} + #[test] fn spoiler() { html(