module TSN.Codegen ( tsn_codegen_config, tsn_db_field_namer -- Used in a TSN.XML.News test. ) where import Data.Char ( toLower, toUpper ) import Data.List.Utils ( join, split ) import Database.Groundhog.TH ( CodegenConfig ( namingStyle ), NamingStyle ( mkDbConstrName, mkDbFieldName, mkExprFieldName ), defaultCodegenConfig, lowerCaseSuffixNamingStyle ) -- | The lowercase naming style for database entities, provided by -- Groundhog. Makes a better starting point than the default. -- lowercase_ns :: NamingStyle lowercase_ns = lowerCaseSuffixNamingStyle -- | A database field name creator. It takes the field name (from a -- record type) and drops the first component determined by -- underscores. So, foo_bar_baz would get mapped to bar_baz in the -- database. tsn_db_field_namer :: String -> String -> Int -> String -> Int -> String tsn_db_field_namer _ _ _ fieldname _ = (join "_") . tail . (split "_") $ fieldname tsn_expr_field_namer :: String -> String -> Int -> String -> Int -> String tsn_expr_field_namer _ _ _ fieldname _ = (join "_") . (map capitalize) . (split "_") $ fieldname where capitalize [] = [] capitalize (c:cs) = (toUpper c : cs) tsn_naming_style :: NamingStyle tsn_naming_style = lowercase_ns { mkDbFieldName = tsn_db_field_namer, mkExprFieldName = tsn_expr_field_namer } tsn_codegen_config :: CodegenConfig tsn_codegen_config = defaultCodegenConfig { namingStyle = tsn_naming_style }