mirror of
https://0xacab.org/sutty/sutty
synced 2024-11-17 04:26:21 +00:00
edff238a36
durante el proceso de compilación de jekyll se cargan todos los datos en memoria, buscando e interpretando todos los archivos del sitio. en el caso de sutty, solo queremos leer alguna información por vez. trabajando en el buscador me dí cuenta que aunque el panel cargue los posts desde la base de datos, sutty seguía leyendo la información completa del sitio, porque respetaba el proceso de lectura de jekyll. con este cambio podemos leer los _data/ por separado de los _posts/ con lo que la carga del sitio es mucho más rápida.
100 lines
2.7 KiB
Ruby
100 lines
2.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
String.include CoreExtensions::String::StripTags
|
|
Jekyll::Document.include CoreExtensions::Jekyll::Document::Path
|
|
|
|
# Definir tags de Liquid que provienen de complementos para que siempre
|
|
# devuelvan contenido vacío.
|
|
%w[seo feed_meta turbolinks].each do |tag|
|
|
Liquid::Template.register_tag(tag, Jekyll::Tags::Empty)
|
|
end
|
|
|
|
Liquid::Template.register_tag('base', Jekyll::Tags::Base)
|
|
|
|
module ActionDispatch
|
|
# Redefinir el formateo de URLs de Rails para eliminar parámetros
|
|
# selectivamente
|
|
module Journey
|
|
Formatter.class_eval do
|
|
alias_method :generate_original, :generate
|
|
|
|
# Eliminar el locale a menos que estemos generando la URL para un
|
|
# Post. Esto es para que las URLs no lleven un ?locale=XX
|
|
# innecesario y además porque generan conflictos en la subida de
|
|
# archivos de ActionText.
|
|
def generate(name, options, path_parameters)
|
|
options.delete(:locale) unless options[:controller] == 'posts'
|
|
|
|
generate_original(name, options, path_parameters)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
# Lazy Loading de Jekyll, deshabilitando la instanciación de elementos
|
|
# que no necesitamos. Esto permite que podamos leer el sitio por partes
|
|
# en lugar de todo junto.
|
|
#
|
|
# TODO: Aplicar monkey patches en otro lado...
|
|
module Jekyll
|
|
Reader.class_eval do
|
|
# No necesitamos otros posts
|
|
def retrieve_posts(_); end
|
|
|
|
# No necesitamos otros directorios
|
|
def retrieve_dirs(_, _, _); end
|
|
|
|
# No necesitamos las páginas
|
|
def retrieve_pages(_, _); end
|
|
|
|
# No necesitamos los archivos estáticos
|
|
def retrieve_static_files(_, _); end
|
|
|
|
# Solo lee los datos
|
|
def read_data
|
|
@site.data = DataReader.new(site).read(site.config["data_dir"])
|
|
end
|
|
|
|
# Lee todos los artículos del sitio
|
|
def read_collections
|
|
read_directories
|
|
read_included_excludes
|
|
sort_files!
|
|
CollectionReader.new(site).read
|
|
end
|
|
end
|
|
|
|
# No necesitamos los archivos de la plantilla
|
|
ThemeAssetsReader.class_eval do
|
|
def read; end
|
|
end
|
|
|
|
# Aplazar la lectura del documento
|
|
Document.class_eval do
|
|
alias_method :read!, :read
|
|
def read; end
|
|
end
|
|
|
|
# Prevenir la instanciación de Time
|
|
#
|
|
# @see {https://github.com/jekyll/jekyll/pull/8425}
|
|
Utils.class_eval do
|
|
def parse_date(input, msg = 'Input could not be parsed.')
|
|
@parse_date_cache ||= {}
|
|
@parse_date_cache[input] ||= Time.parse(input).localtime
|
|
rescue ArgumentError
|
|
raise Errors::InvalidDateError, "Invalid date '#{input}': #{msg}"
|
|
end
|
|
end
|
|
end
|
|
|
|
# JekyllData::Reader del plugin jekyll-data modifica Jekyll::Site#reader
|
|
# para también leer los datos que vienen en el theme.
|
|
module JekyllData
|
|
Reader.class_eval do
|
|
def read_data
|
|
super
|
|
read_theme_data
|
|
end
|
|
end
|
|
end
|