Csvbuilder::Core is part of the csvbuilder-collection
The core contains the shared components used and extended by the exporter and the importer. It is the foundation of the gem csvbuilder and carries the library's architecture, and it is not meant to be used alone.
See:
Install the gem and add to the application's Gemfile by executing:
$ bundle add csvbuilder-core
If bundler is not being used to manage dependencies, install the gem by executing:
$ gem install csvbuilder-core
It is organized into three sections, the public, internal and mixins.
The public exposes the API meant to be used by the other components. The concrete implementation is mainly lying in the Mixins, though.
It represents a CSV row in Csvbuilder. At the core, it defines the standard behaviour, and those behaviours are specialized in Export and Import gems.
In core/concerns/attributes_base, it exposes three main methods:
- original_attributes
- formatted_attributes
- source_attributes
Those methods are collections called on Attribute—for instance, original_attributes call Attribute#value under the hood for the current row.
In core/concerns/model/attributes, we can find the DSL where columns with the options are defined and stored.
class BasicRowModel
  include Csvbuilder::Model
  column :alpha
  column :beta
endIt also carries the headers and the two methods helping with the formatting.
class BasicRowModel
  include Csvbuilder::Model
  class << self
    # Used by Csvbuilder::AttributeBase#formatted_value
    def format_cell(value, column_name, context)
      "- || * #{column_name} * || -"
    end
    # Used by Csvbuilder::Model::Header#formatted_header
    def format_header(column_name, context)
      "~ #{column_name} ~"
    end
  end
end
header = "Alpha"
value  = "alpha one"
AttributeBase.new.formatted_value
# => "- || * alpha one * || -"
AttributeBase.new.value # It can carry some logic.
# => "- || * alpha one * || -"
AttributeBase.new.source_value # Will be always the raw value
# => "alpha one"
Header.new.formatted_header
# => ~ Alpha ~Internally calling respectively:
module Csvbuilder
  module Model
    class Header
      def formatted_header
        row_model_class.format_header(column_name, context)
      end
    end
  end
endand
module Csvbuilder
  class AttributeBase
    def formatted_value
      @formatted_value ||= row_model_class.format_cell(source_value, column_name, row_model.context)
    end
  end
endRepresent the cell value.
Can be found here: core/internal/attribute_base.
It can represent the value through the three following methods:
- source_valueunchanged value
- valueoften the formatted_value, but some logic can be added.
- formatted_value
After checking out the repo, run bin/setup to install dependencies. Then, run rake spec to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and the created tag, and push the .gem file to rubygems.org.
Bug reports and pull requests are welcome on GitHub at https://github.com/joel/csvbuilder-core. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.
The gem is available as open source under the terms of the MIT License.
Everyone interacting in the Csvbuilder::Core project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.

