-import_generic :: (XmlPickler a, PersistEntity b)
- => b -- ^ Dummy Listing instance needed for 'migrate'
- -> (a -> [b]) -- ^ listings getter
- -> Configuration
- -> XmlTree
- -> IO (Maybe Int) -- ^ Return the number of records inserted.
-import_generic dummy g cfg xml
- | backend cfg == Postgres = withPostgresqlConn cs go
- | otherwise = withSqliteConn cs go
- where
- -- | Pull the real connection String out of the configuration.
- cs :: String
- cs = get_connection_string $ connection_string cfg
-
- -- Needs NoMonomorphismRestriction to be allowed to return
- -- different types in the two cases above.
- go = runDbConn $ do
- runMigration defaultMigrationLogger $ migrate dummy
- let root_element = unpickleDoc xpickle xml
- case root_element of
- Nothing -> do
- let msg = "Could not unpickle document in import_generic."
- liftIO $ report_error msg
- return Nothing
- Just elt -> do
- ids <- mapM insert (g elt)
- return $ Just (length ids)
-
-
-
--- | Import TSN.News from an 'XmlTree'.
-import_news :: Configuration -> XmlTree -> IO (Maybe Int)
-import_news = undefined
-
--- | Import TSN.Injuries from an 'XmlTree'.
-import_injuries :: Configuration -> XmlTree -> IO (Maybe Int)
-import_injuries =
- import_generic
- (undefined :: Injuries.Listing)
- Injuries.listings
-
--- | Import TSN.InjuriesDetail from an 'XmlTree'.
-import_injuries_detail :: Configuration -> XmlTree -> IO (Maybe Int)
-import_injuries_detail =
- import_generic
- (undefined :: InjuriesDetail.PlayerListing)
- ( (concatMap InjuriesDetail.player_listings) . InjuriesDetail.listings)
-
-import_file :: Configuration -> FilePath -> IO ()
-import_file cfg path = do
- results <- catchIOError
- parse_and_import
- (\e -> do
- report_error (show e)
- report_error $ "Failed to import file " ++ path ++ "."
- -- Return a nonempty list so we don't claim incorrectly that
- -- we couldn't parse the DTD.
- return [ Nothing ] )
+-- The implementation is straightforward with one exception: since
+-- we are already in arrow world with HXT, the @import_with_dtd@
+-- function is lifted to an 'Arrow' as well with 'arr'. This
+-- prevents us from having to do a bunch of unwrapping and
+-- rewrapping with the associated error checking.
+--
+import_file :: Configuration -- ^ A configuration object needed for the
+ -- 'backend' and 'connection_string'.