sentences.rb revision 510ca4e36c4fb16f11b816ef88255554874aa51f
class Ontology
module Sentences
extend ActiveSupport::Concern
included do
has_many :sentences,
autosave: false,
extend: Methods
has_many :theorems,
autosave: false,
extend: Methods
include GraphStructures::SqlHelper
def translated_sentences
split_translated_sentences.flatten
end
def split_translated_sentences
translated = TranslatedSentence.where(audience_id: self)
sentence_ids = translated.pluck(:sentence_id)
imported =
direct_imported_ontologies.reduce([[], []]) do |arr, ontology|
other_split = ontology.split_translated_sentences
other_translated = other_split.first
other_translated.delete_if do |translated_sentence|
sentence_ids.include?(translated_sentence.sentence_id)
end
other_sentences = other_split.last
other_sentences.delete_if do |sentence|
sentence_ids.include?(sentence.id)
end
other_translated.each { |ot| arr.first << ot }
other_sentences.each { |os| arr.last << os }
arr
end
[translated + imported.first, sentences + imported.last]
end
# Find import-mappings which describe the following mapping:
# some ontology imports self.
def incoming_imports_with_mappings
# INNER JOINS always return an empty result set if the
# ON clause does not match.
Mapping.joins(:symbol_mappings).where(source_id: self, kind: 'import')
end
def create_translated_sentences
query, args = mappings_by_kind_query(self, 'import')
imported_ontology_ids =
pluck_select([query, *args], :ontology_id).reverse
imported_ontology_ids.each do |o_id|
Ontology.find(o_id).create_translated_sentences
end
import_mappings = incoming_imports_with_mappings
if import_mappings.any?
combined_sentences.each do |sentence|
import_mappings.each do |import_mapping|
import_mapping.symbol_mappings.each do |mapping|
translate_sentence(sentence, mapping)
end
end
end
end
end
def translate_sentence(sentence, mapping)
applicable_sentence =
TranslatedSentence.choose_applicable(sentence, mapping)
if mapping.applicable?(applicable_sentence)
translated_text = mapping.apply(applicable_sentence)
audience = mapping.mapping.target
translated_sentence = TranslatedSentence.where(
symbol_mapping_id: mapping,
audience_id: audience,
sentence_id: sentence,
ontology_id: sentence.ontology).first_or_initialize
translated_sentence.translated_text = translated_text
translated_sentence.save
translated_sentence
end
end
protected
def translate_sentences_for(audience_ontology)
mapping = Mapping.where(source_id: audience_ontology,
target_id: self,
kind: 'import').first
if mapping && mapping.symbol_mappings.any?
create_or_fetch_translations(audience_ontology, mapping,
mapping.symbol_mappings)
else
default_translated_sentences
end
end
# If there are no translations applicable, what do you do?
def default_translated_sentences
sentences
end
def create_or_fetch_translations(audience_ontology, mapping, mappings,
overwrite: false)
translations =
TranslatedSentence.for(audience_ontology, sentences_from: self)
if translations.any? && !overwrite
translations
else
translations.delete_all
create_translations(audience_ontology, mapping, mappings)
end
end
def create_translations(_audience_ontology, _mapping, _mappings)
query, args = mappings_by_kind_query(self, 'import')
imported_ontology_ids = pluck_select([query, *args], :id).reverse
imported_ontology_ids.each do |o_id|
Ontology.find(o_id).create_translated_sentences
end
end
end
module Methods
def update_or_create_from_hash(hash, timestamp = Time.now)
sentence = find_or_initialize_by_name(hash['name'])
sentence.imported = hash['imported'] || false
sentence.text = hash['text'].to_s
sentence.range = hash['range']
sentence.updated_at = timestamp
sep = sentence.ontology.parent ? "/" : "//"
sentence.locid = "#{sentence.ontology.locid}#{sep}#{sentence.name}"
sentence.save!
execute_sql(
"DELETE FROM sentences_symbols WHERE sentence_id=#{sentence.id}")
execute_sql(
"INSERT INTO sentences_symbols (sentence_id, symbol_id, ontology_id)
SELECT #{sentence.id}, id, ontology_id FROM symbols WHERE
ontology_id=#{@association.owner.id} AND text IN (?)",
hash['symbols'])
sentence.set_display_text!
sentence
end
end
end
end