princelab/msplinter

View on GitHub
lib/rubabel/molecule/fragmentable/asms_2002_scheme1.rb

Summary

Maintainability
F
5 days
Test Coverage
# Add rules to these two variables as needed
# Rule_names << :rule_names
# Rearrangements << :any_rule_names_that_are_just_rearrangements
require_relative "../fragmentable"

module Rubabel
  class Molecule
    module Fragmentable
      ::Rule_names << def jasms_2002_scheme1_a_c1(only_uniqs: true, fragment_adduct_state: :as_published)
        # Create a fragmentation block method
        fragment_sets = []
        fragment = lambda do |tbcc, o, lc|
          # Duplication and mapping identity to new atoms
          nmol = self.dup
          to_be_carbonyl_carbon = nmol.atom(tbcc.id)
          oxygen = nmol.atom(o.id)
          link_carbon = nmol.atom(lc.id)
          # manipulate bonds
          nmol.delete_bond(to_be_carbonyl_carbon, link_carbon)
          to_be_carbonyl_carbon.get_bond(oxygen).bond_order = 2
          nmol.split
        end

        # Call the block on any search strings which make sense in the context of the code
        self.matches("C=CC([OH1])CN", only_uniqs).each do |carbon2_1, carbon2_2, to_be_carbonyl_carbon, oxygen, link_carbon, nitrogen|
          fragment_sets << fragment.call(to_be_carbonyl_carbon, oxygen,link_carbon)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end

      ::Rule_names << def jasms_2002_scheme1_b_d1(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |n, tcc, o|
          #duplications and mapping
          nmol = self.dup
          nitrogen = nmol.atom(n.id)
          to_cyclize_carbon = nmol.atom(tcc.id)
          oxygen = nmol.atom(o.id)
          # manipulate bonds
          nmol.delete_bond(nitrogen, to_cyclize_carbon)
          nmol.add_bond!(to_cyclize_carbon, oxygen)
          nmol.split
        end

        # call the block search strings
        self.matches("N[Ch1]C[OH1]", only_uniqs).each do |nitrogen, to_cyclize_carbon, carbon, oxygen|
          fragment_sets << fragment.call(nitrogen, to_cyclize_carbon, oxygen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rearrangements << def jasms_2002_scheme1_b_d1_water_loss(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |lo, lc, lh|
          #duplications and mapping
          nmol = self.dup
          leaving_oxygen = nmol.atom(lo.id)
          link_carbon = nmol.atom(lc.id)
          losing_hydrogen_atom = nmol.atom(lh.id)
          # manipulate bonds
          bond_order = leaving_oxygen.get_bond(link_carbon).bond_order
          nmol.delete_bond(leaving_oxygen, link_carbon)
          losing_hydrogen_atom.get_bond(link_carbon).bond_order += bond_order
          nmol.split
        end

        # call the block search strings
        self.matches("[Oh1]C(C=C)[Ch1][OX2h0]", only_uniqs).each do |leaving_oxygen, link_carbon,carbon1, carbon2, losing_hydrogen_carbon, oxygen2|
          fragment_sets << fragment.call(leaving_oxygen, link_carbon, losing_hydrogen_carbon)
        end
        self.matches("O=C[Nh2]", only_uniqs).each do |leaving_oxygen, link_carbon, losing_hydrogen_nitrogen|
          fragment_sets << fragment.call(leaving_oxygen, link_carbon, losing_hydrogen_nitrogen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end

      ::Rearrangements << def jasms_2002_scheme1_b_d1_formaldehyde_loss(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |tco, leavingc, leftc|
          #duplications and mapping
          nmol = self.dup
          to_carbonyl_oxygen = nmol.atom(tco.id)
          leaving_carbon = nmol.atom(leavingc.id)
          left_carbon = nmol.atom(leftc.id)
          # manipulate bonds
          nmol.delete_bond(leaving_carbon, left_carbon)
          to_carbonyl_oxygen.get_bond(leaving_carbon).bond_order += 1
          nmol.split
        end

        # call the block search strings
     #     binding.pry if self.matches("[Oh1]C[CX4]([Oh0])[CX4]C=C", only_uniqs).size > 0
        self.matches("[Oh1]C[CX4]([Oh0])[CX4]C=C", only_uniqs).each do |to_carbonyl_oxygen, leaving_carbon,left_carbon, rest|
          fragment_sets << fragment.call(to_carbonyl_oxygen, leaving_carbon, left_carbon)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rule_names << def jasms_2002_scheme1_c_e1(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |n, cc, o, tbvc|
          #duplications and mapping
          nmol = self.dup
          nitrogen = nmol.atom(n.id)
          carbonyl_carbon = nmol.atom(cc.id)
          oxygen = nmol.atom(o.id)
          to_be_vinyllic_carbon = nmol.atom(tbvc.id)
          # manipulate bonds
          nmol.delete_bond(nitrogen, carbonyl_carbon)
          carbonyl_carbon.get_bond(to_be_vinyllic_carbon).bond_order += 1
          nmol.split
        end

        # call the block search strings
        self.matches("NC(=O)[CH2]", only_uniqs).each do |nitrogen, carbonyl_carbon, oxygen, to_be_vinyllic_carbon|
          fragment_sets << fragment.call(nitrogen, carbonyl_carbon, oxygen, to_be_vinyllic_carbon)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rule_names << def jasms_2002_scheme1_c_e1aprime(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |co, c1, c3, lo, n|
          #duplications and mapping
          nmol = self.dup
          cyclized_oxygen = nmol.atom(co.id)
          carbon1 = nmol.atom(c1.id)
          carbon3 = nmol.atom(c3.id)
          leaving_oxygen = nmol.atom(lo.id)
          nitrogen = nmol.atom(n.id)
          # manipulate bonds
          nmol.delete_bond(carbon3, leaving_oxygen)
          nmol.add_bond!(carbon3, cyclized_oxygen)
          nitrogen.remove_a_proton!
          nmol.split
        end
        # call the block search strings
        self.matches("[Oh1]CC(C[Oh1])N", only_uniqs).each do |cyclized_oxygen, carbon1, carbon2, carbon3, leaving_oxygen, nitrogen|
          fragment_sets << fragment.call(cyclized_oxygen, carbon1, carbon3, leaving_oxygen, nitrogen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      alias :jasms_2002_scheme1_c_e1aprimeprime_formaldehyde_loss :jasms_2002_scheme1_b_d1_formaldehyde_loss
      ::Rule_names << :jasms_2002_scheme1_c_e1aprimeprime_formaldehyde_loss
      ::Rule_names << def jasms_2002_scheme1_c_e1bprime(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |n, c2, lo|
          #duplications and mapping
          nmol = self.dup
          nitrogen = nmol.atom(n.id)
          carbon2 = nmol.atom(c2.id)
          leaving_oxygen = nmol.atom(lo.id)
          # manipulate bonds
          nmol.delete_bond(carbon2, leaving_oxygen)
          nmol.add_bond!(carbon2, nitrogen)
          nitrogen.remove_a_proton!
          nmol.split
        end

        # call the block search strings
        self.matches("NC[CH2](O)", only_uniqs).each do |nitrogen, carbon, carbon2, leaving_oxygen|
          fragment_sets << fragment.call(nitrogen, carbon2, leaving_oxygen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rule_names << def jasms_2002_scheme1_c_e1b_to_d1bprime(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |co, c, n|
          #duplications and mapping
          nmol = self.dup
          nitrogen = nmol.atom(n.id)
          carbon = nmol.atom(c.id)
          cyclized_oxygen = nmol.atom(co.id)
          # manipulate bonds
          nmol.delete_bond(nitrogen, carbon)
          nmol.add_bond!(carbon, cyclized_oxygen)
          nitrogen.remove_a_proton!
          nmol.split
        end

        # call the block search strings
        self.matches("[Oh1]CC(N)", only_uniqs).each do |cyclized_oxygen, carbon, carbon2, nitrogen|
          fragment_sets << fragment.call(cyclized_oxygen, carbon2, nitrogen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      alias :jasms_2002_scheme1_c_e1b_to_d1b :jasms_2002_scheme1_c_e1b_to_d1bprime
      ::Rule_names << :jasms_2002_scheme1_c_e1b_to_d1b
      ::Rearrangements << def jasms_2002_scheme1_c_e1_aprimeprime_formaldehyde_loss(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |*arr|
          #duplications and mapping
          (nmol,(cyclized_oxygen, freed_carbon, carbon_linked_to_nitrogen, carbon_linker, nitrogen)) = self.dup_molecule(arr)
          # manipulate bonds
          nmol.delete_bond(carbon_linker, cyclized_oxygen)
          nmol.delete_bond(carbon_linked_to_nitrogen, freed_carbon)
          freed_carbon.get_bond(cyclized_oxygen).bond_order = 2
          carbon_linked_to_nitrogen.get_bond(carbon_linker).bond_order = 2
          nitrogen.remove_a_proton!
          nmol.split
        end
        # call the block search strings
        self.matches("[O;R][C;R]-[C;R](N)[C;R;r4]C=C", only_uniqs).each do |cyclized_oxygen, freed_carbon, carbon_linked_to_nitrogen, nitrogen, carbon_linker,c1, c2|
          fragment_sets << fragment.call(cyclized_oxygen, freed_carbon, carbon_linked_to_nitrogen, carbon_linker,nitrogen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rearrangements << def jasms_2002_scheme1_c_e1_abprimeprime_water_loss(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |*arr|
          #duplications and mapping
          (nmol,(carbon_linker, alcohol_carbon, oxygen, nitrogen)) = self.dup_molecule(arr)
          # manipulate bonds
          nmol.delete_bond(alcohol_carbon, oxygen)
          carbon_linker.get_bond(alcohol_carbon).bond_order = 2
          nitrogen.charge = 0
          nmol.split
        end
        # call the block search strings
        self.matches("[C;R;r3][N;R;r3][C;R;r3][Ch1;!R](O)C=C", only_uniqs).each do |c1, nitrogen, carbon_linker, alcohol_carbon, oxygen, c2,c3|
          fragment_sets << fragment.call(carbon_linker, alcohol_carbon, oxygen, nitrogen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rule_names << def jasms_2002_scheme1_c_e2bprime(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |*arr|
          #duplications and mapping
          (nmol,(nitrogen, carbon, leaving_oxygen)) = self.dup_molecule(arr)
          # remove the adduct
          nmol.adducts.delete_if {|m| m.csmiles == "[Li+]"}
          # manipulate bonds
          nmol.delete_bond(carbon, leaving_oxygen)
          nmol.add_bond!(carbon, nitrogen)
          #nitrogen.remove_a_proton!
          nmol.split
        end
        self.matches("NC[CH2](O)", only_uniqs).each do |nitrogen, carbon, carbon2, leaving_oxygen|
          fragment_sets << fragment.call(nitrogen, carbon2, leaving_oxygen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rearrangements << ::Rule_names.last
      ::Rule_names << def jasms_2002_scheme1_c_e2aprime(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |*arr|
          #duplications and mapping
          (nmol,(nitrogen, branch_carbon, leaving_oxygen, cyclized_oxygen)) = self.dup_molecule(arr)
          # remove the adduct
          nmol.adducts.delete_if {|m| m.csmiles == "[Li+]"}
          # manipulate bonds
          nmol.delete_bond(leaving_oxygen, branch_carbon)
          nmol.add_bond!(branch_carbon, cyclized_oxygen)
          #nitrogen.remove_a_proton!
          nmol.split
        end
        self.matches("NC(CO)C(O)C=C", only_uniqs).each do |nitrogen, carbon_linker, branch_carbon, leaving_oxygen, alcohol_carbon, cyclized_oxygen, carbon2, carbon3|
          fragment_sets << fragment.call(nitrogen, branch_carbon, leaving_oxygen, cyclized_oxygen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rearrangements << ::Rule_names.last
      ::Rule_names << def jasms_2002_scheme1_c_e2aprime_formaldehyde_loss(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |*arr|
          #duplications and mapping
          (nmol,(carbon1, carbon2, oxygen, carbon3)) = self.dup_molecule(arr)
          # manipulate bonds
          nmol.delete_bond(carbon1, carbon2)
          nmol.delete_bond(oxygen, carbon3)
          oxygen.get_bond(carbon2).bond_order = 2
          begin
            carbon1.get_bond(carbon3).bond_order = 2
          rescue
            binding.pry
          end
          #nitrogen.remove_a_proton!
          nmol.split
        end
        self.matches("N[R;C;r4][R;C;r4][R;O][R;C;r4]C=C", only_uniqs).each do |nitrogen, carbon1, carbon2, oxygen, carbon3, carbon4, carbon5|
          fragment_sets << fragment.call(carbon1, carbon2, oxygen, carbon3)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rearrangements << ::Rule_names.last
      ::Rule_names << def jasms_2002_scheme1_c_e2bprime_water_loss(only_uniqs: true, fragment_adduct_state: :as_published)
        fragment_sets = []
        fragment = lambda do |*arr|
          #duplications and mapping
          (nmol,(ring_carbon2, alcohol_carbon, oxygen, nitrogen)) = self.dup_molecule(arr)
          # manipulate bonds
          nmol.delete_bond(alcohol_carbon, oxygen)
          alcohol_carbon.get_bond(ring_carbon2).bond_order = 2
          nitrogen.inc_implicit_valence!
          #binding.pry
          nmol.split
        end
        self.matches("N[R;C][R;C]C(O)C=C", only_uniqs).each do |nitrogen, ring_carbon1, ring_carbon2, alcohol_carbon, oxygen, carbon1, carbon2|
          fragment_sets << fragment.call(ring_carbon2, alcohol_carbon, oxygen, nitrogen)
        end
        if self.adducts.empty?
          fragment_sets.flatten
        else
          resp = case fragment_adduct_state
          when :force_adducts
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            fragment_sets
          when :as_published
            # CONFIGURE THIS HERE BY Turning OFF the adduct line
            # ADDUCT LINE
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            # This line must always be here
            fragment_sets.flatten
          when :no_adducts
            fragment_sets.flatten
          when :all
            dups = fragment_sets.flatten.map(&:dup) 
            fragment_sets.flatten.map {|frag| frag.adducts.push(*self.adducts)}
            dups + fragment_sets.flatten
          end
        end
      end
      ::Rearrangements << ::Rule_names.last
  end # Fragmentable
end # Molecule
end #Rubabel


if $0 == __FILE__
  require 'bundler/setup'
  require 'rubabel'
  require 'pry'
  mol = Rubabel["LMGP04010962", :lmid]
  mol = Rubabel["CCCCCCCCCCCCCCCC(=O)OC(COP(=O)([O-])[O-])COC(=O)CCCCCCC/C=C\\CCCCCCCC"]
  p mol.rule_name
end