import Data.Maybe ( fromMaybe )
 import Data.Time ( UTCTime(..) )
 import Data.Tuple.Curry ( uncurryN )
-import qualified Data.Vector.HFixed as H ( HVector, convert )
+import qualified Data.Vector.HFixed as H ( HVector, cons, convert, tail )
 import Data.Typeable ( Typeable )
 import Database.Groundhog (
   insert,
 instance H.HVector MLBBoxScoreGameBreakdownXml
 
 
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreHomerunStatsListingBatter =
   MLBBoxScoreHomerunStatsListingBatter {
-    db_batter_first_name :: String,
-    db_batter_last_name :: String,
-    db_batter_rbis :: Int,
-    db_batter_id :: Int }
+    _db_batter_first_name :: String,
+    _db_batter_last_name :: String,
+    _db_batter_rbis :: Int,
+    _db_batter_id :: Int }
   deriving (Data, Eq, GHC.Generic, Show, Typeable)
 
 -- | For 'H.convert'
 instance XmlImportFk MLBBoxScoreHomerunStatsListingXml
 
 
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreHomerunStatsListingPitcher =
   MLBBoxScoreHomerunStatsListingPitcher {
-    db_mlb_box_score_homerun_stats_listings_id ::
+    _db_mlb_box_score_homerun_stats_listings_id ::
       DefaultKey MLBBoxScoreHomerunStatsListing,
-    db_homeruns_off_pitcher :: Int,
-    db_pitcher_first_name :: String,
-    db_pitcher_last_name :: String,
-    db_pitchers_pitcher_id :: Int }
+    _db_homeruns_off_pitcher :: Int,
+    _db_pitcher_first_name :: String,
+    _db_pitcher_last_name :: String,
+    _db_pitchers_pitcher_id :: Int }
+  deriving ( GHC.Generic )
 
+
+-- | For 'H.cons' and 'H.convert'.
+--
+instance H.HVector MLBBoxScoreHomerunStatsListingPitcher
+
+
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreHomerunStatsListingPitcherXml =
   MLBBoxScoreHomerunStatsListingPitcherXml {
-    xml_homeruns_off_pitcher :: Int,
-    xml_pitcher_first_name :: String,
-    xml_pitcher_last_name :: String,
-    xml_pitchers_pitcher_id :: Int }
+    _xml_homeruns_off_pitcher :: Int,
+    _xml_pitcher_first_name :: String,
+    _xml_pitcher_last_name :: String,
+    _xml_pitchers_pitcher_id :: Int }
   deriving (Eq, GHC.Generic, Show)
 
 -- | For 'H.convert'
   -- | To convert an 'MLBBoxScoreHomerunStatsListingPitcherXml' to an
   --   'MLBBoxScoreHomerunStatsListingPitcher', we add the foreign key.
   --
-  from_xml_fk fk MLBBoxScoreHomerunStatsListingPitcherXml{..} =
-    MLBBoxScoreHomerunStatsListingPitcher {
-      db_mlb_box_score_homerun_stats_listings_id = fk,
-      db_homeruns_off_pitcher = xml_homeruns_off_pitcher,
-      db_pitcher_first_name = xml_pitcher_first_name,
-      db_pitcher_last_name = xml_pitcher_last_name,
-      db_pitchers_pitcher_id = xml_pitchers_pitcher_id }
+  from_xml_fk = H.cons
 
 
 -- | This allows us to insert the XML representation
 
 
 -- Team Breakdown
+
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreTeamBreakdown =
   MLBBoxScoreTeamBreakdown {
-    db_runs :: Int,
-    db_hits :: Int,
-    db_errors :: Int }
+    _db_runs :: Int,
+    _db_hits :: Int,
+    _db_errors :: Int }
+  deriving ( GHC.Generic )
+
+-- | For 'H.cons' and 'H.convert'.
+--
+instance H.HVector MLBBoxScoreTeamBreakdown
+
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreTeamBreakdownXml =
   MLBBoxScoreTeamBreakdownXml {
     xml_runs_by_innings :: [MLBBoxScoreRunsByInningsXml],
-    xml_runs :: Int,
-    xml_hits :: Int,
-    xml_errors :: Int }
+    _xml_runs :: Int,
+    _xml_hits :: Int,
+    _xml_errors :: Int }
   deriving (Eq, GHC.Generic, Show)
 
 
   --   'MLBBoxScoreTeamBreakdown', we just drop the
   --   'xml_runs_by_innings'.
   --
-  from_xml MLBBoxScoreTeamBreakdownXml{..} =
-    MLBBoxScoreTeamBreakdown {
-      db_runs = xml_runs,
-      db_hits = xml_hits,
-      db_errors = xml_errors }
+  from_xml = H.tail
 
 instance XmlImport MLBBoxScoreTeamBreakdownXml
 
 -- Runs by innings
+
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreRunsByInnings =
   MLBBoxScoreRunsByInnings {
-    db_mlb_box_scores_team_breakdowns_id :: DefaultKey
+    _db_mlb_box_scores_team_breakdowns_id :: DefaultKey
                                            MLBBoxScoreTeamBreakdown,
-    db_runs_by_innings_inning_number :: Int,
-    db_runs_by_innings_runs   :: Int }
+    _db_runs_by_innings_inning_number :: Int,
+    _db_runs_by_innings_runs   :: Int }
+  deriving ( GHC.Generic )
+
+
+-- | For 'H.cons' and 'H.convert'.
+instance H.HVector MLBBoxScoreRunsByInnings
 
+
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreRunsByInningsXml =
   MLBBoxScoreRunsByInningsXml {
-    xml_runs_by_innings_inning_number :: Int,
-    xml_runs_by_innings_runs   :: Int }
+    _xml_runs_by_innings_inning_number :: Int,
+    _xml_runs_by_innings_runs   :: Int }
   deriving (Eq, GHC.Generic, Show)
 
 
   --   'MLBBoxScoreRunsByInnings', we add the foreign key and copy
   --   everything else verbatim.
   --
-  from_xml_fk fk MLBBoxScoreRunsByInningsXml{..} =
-    MLBBoxScoreRunsByInnings {
-      db_mlb_box_scores_team_breakdowns_id = fk,
-      db_runs_by_innings_inning_number = xml_runs_by_innings_inning_number,
-      db_runs_by_innings_runs = xml_runs_by_innings_runs }
+  from_xml_fk = H.cons
 
 
 -- | This allows us to insert the XML representation
 -- * MLBBoxScoreMiscPitchingStatsIntentionalWalk
 
 -- | Database representation of an intentional walk. The weird
---   prefixes avoid collisiont with the other batter/pitcher_ids, and
+--   prefixes avoid collisions with the other batter/pitcher_ids, and
 --   still get mangled properly by Groundhog.
 --
+--   The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreMiscPitchingStatsIntentionalWalk =
   MLBBoxScoreMiscPitchingStatsIntentionalWalk {
-    dbiw_mlb_box_scores_id :: DefaultKey MLBBoxScore,
-    dbiw_batter_id :: Int,
-    dbiw_pitcher_id :: Int,
-    dbiw_number_of_times_walked :: Int }
+    _dbiw_mlb_box_scores_id :: DefaultKey MLBBoxScore,
+    _dbiw_batter_id :: Int,
+    _dbiw_pitcher_id :: Int,
+    _dbiw_number_of_times_walked :: Int }
+  deriving ( GHC.Generic )
 
 
+-- | For 'H.cons' and 'H.convert'.
+--
+instance H.HVector MLBBoxScoreMiscPitchingStatsIntentionalWalk
+
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreMiscPitchingStatsIntentionalWalkXml =
   MLBBoxScoreMiscPitchingStatsIntentionalWalkXml {
-    xml_iw_batter_id :: Int,
-    xml_iw_pitcher_id :: Int,
-    xml_iw_number_of_times_walked :: Int }
+    _xml_iw_batter_id :: Int,
+    _xml_iw_pitcher_id :: Int,
+    _xml_iw_number_of_times_walked :: Int }
   deriving (Eq, GHC.Generic, Show)
 
 -- | For 'H.convert'.
   --   to an 'MLBBoxScoreMiscPitchingStatsIntentionalWalk', we add the
   --   foreign key and copy everything else verbatim.
   --
-  from_xml_fk fk MLBBoxScoreMiscPitchingStatsIntentionalWalkXml{..} =
-    MLBBoxScoreMiscPitchingStatsIntentionalWalk {
-    dbiw_mlb_box_scores_id = fk,
-    dbiw_batter_id = xml_iw_batter_id,
-    dbiw_pitcher_id = xml_iw_pitcher_id,
-    dbiw_number_of_times_walked = xml_iw_number_of_times_walked }
+  from_xml_fk = H.cons
 
 
 -- | This allows us to insert the XML representation
 
 -- * MLBBoxScoreMiscPitchingStatsHitByPitchXml
 
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreMiscPitchingStatsHitByPitch =
   MLBBoxScoreMiscPitchingStatsHitByPitch {
-    dbhbp_mlb_box_scores_id :: DefaultKey MLBBoxScore,
-    dbhbp_batter_id :: Int,
-    dbhbp_pitcher_id :: Int,
-    dbhbp_number_of_times_hit :: Int }
+    _dbhbp_mlb_box_scores_id :: DefaultKey MLBBoxScore,
+    _dbhbp_batter_id :: Int,
+    _dbhbp_pitcher_id :: Int,
+    _dbhbp_number_of_times_hit :: Int }
+  deriving ( GHC.Generic )
 
+-- | For 'H.cons' and 'H.convert'.
+--
+instance H.HVector MLBBoxScoreMiscPitchingStatsHitByPitch
 
 instance ToDb MLBBoxScoreMiscPitchingStatsHitByPitchXml where
   -- | The database analogue of a
   --   to an 'MLBBoxScoreMiscPitchingStatsHitByPitch', we add the
   --   foreign key and copy everything else verbatim.
   --
-  from_xml_fk fk MLBBoxScoreMiscPitchingStatsHitByPitchXml{..} =
-    MLBBoxScoreMiscPitchingStatsHitByPitch {
-    dbhbp_mlb_box_scores_id = fk,
-    dbhbp_batter_id = xml_hbp_batter_id,
-    dbhbp_pitcher_id = xml_hbp_pitcher_id,
-    dbhbp_number_of_times_hit = xml_hbp_number_of_times_hit }
+  from_xml_fk = H.cons
 
 
 -- | This allows us to insert the XML representation
 instance XmlImportFk MLBBoxScoreMiscPitchingStatsHitByPitchXml
 
 
+-- | The leading underscores prevent unused field warnings.
+--
 data MLBBoxScoreMiscPitchingStatsHitByPitchXml =
   MLBBoxScoreMiscPitchingStatsHitByPitchXml {
-    xml_hbp_batter_id :: Int,
-    xml_hbp_pitcher_id :: Int,
-    xml_hbp_number_of_times_hit :: Int }
+    _xml_hbp_batter_id :: Int,
+    _xml_hbp_pitcher_id :: Int,
+    _xml_hbp_number_of_times_hit :: Int }
   deriving (Eq, GHC.Generic, Show)
 
 
   constructors:
     - name: MLBBoxScoreMiscPitchingStatsIntentionalWalk
       fields:
-        - name: dbiw_mlb_box_scores_id
+        - name: _dbiw_mlb_box_scores_id
           reference:
             onDelete: cascade
 
   constructors:
     - name: MLBBoxScoreMiscPitchingStatsHitByPitch
       fields:
-        - name: dbhbp_mlb_box_scores_id
+        - name: _dbhbp_mlb_box_scores_id
           reference:
             onDelete: cascade
 
 
 - embedded: MLBBoxScoreHomerunStatsListingBatter
   fields:
-    - name: db_batter_first_name
+    - name: _db_batter_first_name
       dbName: batter_first_name
-    - name: db_batter_last_name
+    - name: _db_batter_last_name
       dbName: batter_last_name
-    - name: db_batter_rbis
+    - name: _db_batter_rbis
       dbName: batter_rbis
-    - name: db_batter_id
+    - name: _db_batter_id
       dbName: batter_id
 
 - entity: MLBBoxScoreHomerunStatsListing
   constructors:
     - name: MLBBoxScoreHomerunStatsListingPitcher
       fields:
-        - name: db_mlb_box_score_homerun_stats_listings_id
+        - name: _db_mlb_box_score_homerun_stats_listings_id
           reference:
             onDelete: cascade
 
   constructors:
     - name: MLBBoxScoreRunsByInnings
       fields:
-        - name: db_mlb_box_scores_team_breakdowns_id
+        - name: _db_mlb_box_scores_team_breakdowns_id
           reference:
             onDelete: cascade