--
module TSN.Team (
HTeam(..),
+ FromXmlFkTeams(..),
Team(..),
VTeam(..),
-- * WARNING: these are private but exported to silence warnings
-- System imports
import Database.Groundhog () -- Required for some String instance
+import Database.Groundhog.Core ( PersistEntity(..) )
import Database.Groundhog.TH (
defaultCodegenConfig,
groundhog,
mkPersist )
+-- Local imports
+import Xml ( Child(..), Db(..) )
+
-- * Team
type: constraint
fields: [team_id]
|]
+
+
+
+-- | A further refinement of 'FromXmlFk'. These types need not only a
+-- foreign key to a parent in order to make the XML -> DB
+-- conversion, but also two foreign keys to away/home teams (as
+-- represented in "TSN.Team").
+--
+class (Child a, ToDb a) => FromXmlFkTeams a where
+ -- | The function that produces a @Db a@ out of a parent foreign
+ -- key, two team foreign keys, and an @a@. The parameter order makes
+ -- it easier to map this function over a bunch of things.
+ from_xml_fk_teams :: DefaultKey (Parent a)
+ -> DefaultKey Team -- ^ The away team FK
+ -> DefaultKey Team -- ^ The home team FK
+ -> a
+ -> Db a
xp_time,
xp_time_dots,
xp_time_stamp )
-import TSN.Team ( Team(..), HTeam(..), VTeam(..) )
+import TSN.Team (
+ FromXmlFkTeams(..),
+ HTeam(..),
+ Team(..),
+ VTeam(..) )
import TSN.XmlImport (
XmlImport(..),
XmlImportFkTeams(..) )
import Xml (
Child(..),
FromXml(..),
- FromXmlFkTeams(..),
ToDb(..),
pickle_unpickle,
unpickleable,
tsn_codegen_config )
import TSN.DbImport ( DbImport(..), ImportResult(..), run_dbmigrate )
import TSN.Picklers ( xp_date_padded, xp_time, xp_time_stamp )
-import TSN.Team ( Team(..) )
+import TSN.Team ( FromXmlFkTeams(..), Team(..) )
import TSN.XmlImport ( XmlImport(..), XmlImportFkTeams(..) )
import Xml (
Child(..),
FromXml(..),
- FromXmlFkTeams(..),
ToDb(..),
pickle_unpickle,
unpickleable,
import TSN.DbImport ( DbImport(..), ImportResult(..), run_dbmigrate )
import TSN.Location ( Location(..), pickle_location )
import TSN.Picklers ( xp_time_stamp )
-import TSN.Team ( Team(..), HTeam(..), VTeam(..) )
+import TSN.Team (
+ FromXmlFkTeams(..),
+ HTeam(..),
+ Team(..),
+ VTeam(..) )
import TSN.XmlImport ( XmlImport(..), XmlImportFkTeams(..) )
import Xml (
Child(..),
FromXml(..),
- FromXmlFkTeams(..),
ToDb(..),
pickle_unpickle,
unpickleable,
-- Local imports.
-import TSN.Team ( Team(..) )
+import TSN.Team ( FromXmlFkTeams(..), Team(..) )
import Xml (
Child(..),
FromXml(..),
FromXmlFk(..),
- FromXmlFkTeams(..),
ToDb(..) )
DtdName(..),
FromXml(..),
FromXmlFk(..),
- FromXmlFkTeams(..),
ToDb(..),
parse_opts,
pickle_unpickle,
yes )
--- Local imports.
-import TSN.Team ( Team(..) )
-
-- | Common associated type shared by 'FromXml' and 'FromXmlFk'. This
-- basically just forces the client to define the \"database
-- | A class for XML representations which are children of other
-- elements. The foal is to associate a child XML element with its
-- parent element's database type. This is required to construct the
--- database analogue of @a@ in the 'FromXmlFk' and 'FromXmlFkTeams'
--- classes.
+-- database analogue of @a@ in 'FromXmlFk'.
--
class Child a where
-- | The type of our parent object, i.e. to the type to whom our
from_xml_fk :: DefaultKey (Parent a) -> a -> Db a
--- | A further refinement of 'FromXmlFk'. These types need not only a
--- foreign key to a parent in order to make the XML -> DB
--- conversion, but also two foreign keys to away/home teams (as
--- represented in "TSN.Team").
---
-class (Child a, ToDb a) => FromXmlFkTeams a where
- -- | The function that produces a @Db a@ out of a parent foreign
- -- key, two team foreign keys, and an @a@. The parameter order makes
- -- it easier to map this function over a bunch of things.
- from_xml_fk_teams :: DefaultKey (Parent a)
- -> DefaultKey Team -- ^ The away team FK
- -> DefaultKey Team -- ^ The home team FK
- -> a
- -> Db a
-
-- | Represents the DTD filename (\"SYSTEM\") part of the DOCTYPE
-- definition.