Sha256: 56c77089006e37d4c8100dcb4166614a8a912c7e60b00df8f9832aa6c45b447c

Contents?: true

Size: 1.88 KB

Versions: 9

Compression:

Stored size: 1.88 KB

Contents

# frozen_string_literal: true

module Jekyll
  module Drops
    class SiteDrop < Drop
      extend Forwardable

      mutable false

      def_delegator  :@obj, :site_data, :data
      def_delegators :@obj, :time, :pages, :static_files, :tags, :categories

      private def_delegator :@obj, :config, :fallback_data

      def [](key)
        if @obj.collections.key?(key) && key != "posts"
          @obj.collections[key].docs
        else
          super(key)
        end
      end

      def key?(key)
        (@obj.collections.key?(key) && key != "posts") || super
      end

      def posts
        @site_posts ||= @obj.posts.docs.sort { |a, b| b <=> a }
      end

      def html_pages
        @site_html_pages ||= @obj.pages.select do |page|
          page.html? || page.url.end_with?("/")
        end
      end

      def collections
        @site_collections ||= @obj.collections.values.sort_by(&:label).map(&:to_liquid)
      end

      # `Site#documents` cannot be memoized so that `Site#docs_to_write` can access the
      # latest state of the attribute.
      #
      # Since this method will be called after `Site#pre_render` hook,
      # the `Site#documents` array shouldn't thereafter change and can therefore be
      # safely memoized to prevent additional computation of `Site#documents`.
      def documents
        @documents ||= @obj.documents
      end

      # `{{ site.related_posts }}` is how posts can get posts related to
      # them, either through LSI if it's enabled, or through the most
      # recent posts.
      # We should remove this in 4.0 and switch to `{{ post.related_posts }}`.
      def related_posts
        return nil unless @current_document.is_a?(Jekyll::Document)
        @current_document.related_posts
      end
      attr_writer :current_document

      # return nil for `{{ site.config }}` even if --config was passed via CLI
      def config; end
    end
  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
jekyll-3.10.0 lib/jekyll/drops/site_drop.rb
jekyll-3.9.5 lib/jekyll/drops/site_drop.rb
jekyll-3.9.4 lib/jekyll/drops/site_drop.rb
jekyll-3.9.3 lib/jekyll/drops/site_drop.rb
jekyll-3.9.2 lib/jekyll/drops/site_drop.rb
jekyll-3.9.1 lib/jekyll/drops/site_drop.rb
jekyll-3.9.0 lib/jekyll/drops/site_drop.rb
jekyll-3.8.7 lib/jekyll/drops/site_drop.rb
jekyll-3.8.6 lib/jekyll/drops/site_drop.rb