X-Git-Url: http://gitweb.michael.orlitzky.com/?a=blobdiff_plain;f=src%2FTSN%2FCodegen.hs;h=38aede40cae87a672ff862143ff950a34b899abd;hb=f6a6e5d00b4fdc8c3b9467c1154fb2256ae55179;hp=cd5853c9dfccbfa4a0f873e3dd662ab60b8aca65;hpb=c792c3bb79e83b5bb8d65984de51f2416b7a2d8e;p=dead%2Fhtsn-import.git diff --git a/src/TSN/Codegen.hs b/src/TSN/Codegen.hs index cd5853c..38aede4 100644 --- a/src/TSN/Codegen.hs +++ b/src/TSN/Codegen.hs @@ -4,10 +4,11 @@ module TSN.Codegen ( ) where +import Data.Char ( toLower, toUpper ) import Data.List.Utils ( join, split ) import Database.Groundhog.TH ( CodegenConfig ( namingStyle ), - NamingStyle ( mkDbFieldName ), + NamingStyle ( mkDbConstrName, mkDbFieldName, mkExprFieldName ), defaultCodegenConfig ) default_ns :: NamingStyle @@ -21,8 +22,21 @@ tsn_db_field_namer :: String -> String -> Int -> String -> Int -> String tsn_db_field_namer _ _ _ fieldname _ = (join "_") . tail . (split "_") $ fieldname +tsn_db_constr_namer :: String -> String -> Int -> String +tsn_db_constr_namer _ constrname _ = + map toLower constrname + +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 = default_ns { mkDbFieldName = tsn_db_field_namer } +tsn_naming_style = default_ns { mkDbConstrName = tsn_db_constr_namer, + mkDbFieldName = tsn_db_field_namer, + mkExprFieldName = tsn_expr_field_namer } tsn_codegen_config :: CodegenConfig tsn_codegen_config =