// Copyright (C) Stichting Deltares 2018. All rights reserved.
//
// This file is part of the application DAM - Clients Library.
//
// DAM - UI is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
//
// All names, logos, and references to "Deltares" are registered trademarks of
// Stichting Deltares and remain full property of Stichting Deltares at all times.
// All rights reserved.
using System;
namespace Deltares.Maps
{
public class FeatureImporter : IFeatureImporter
{
private readonly IFeatureRepository repository;
private IReader reader;
public FeatureImporter(IFeatureRepository repository, IReader reader)
{
if (repository == null)
{
throw new ArgumentNullException("repository");
}
if (reader == null)
{
throw new ArgumentNullException("reader");
}
this.repository = repository;
this.reader = reader;
}
#region Implementation of IGeometryRepositoryImporter
public IFeatureRepository Repository
{
get { return repository; }
}
public IReader Reader
{
set { reader = value; }
}
public void Import()
{
repository.Add(reader.Read());
}
#endregion
public static void ImportFromShapeFile(ShapeFileLocation shapeFileLocation, IFeatureRepository featureRepository,
bool ignoreAttributeData = false)
{
if (shapeFileLocation == null)
{
throw new ArgumentNullException("shapeFileLocation");
}
if (featureRepository == null)
{
throw new ArgumentNullException("featureRepository");
}
try
{
IReader reader = new ShapeFileReader(shapeFileLocation)
{
IgnoreAttributeData = ignoreAttributeData
};
IFeatureImporter importer = new FeatureImporter(featureRepository, reader);
importer.Import();
}
catch (Exception e)
{
throw new FeatureImportException(shapeFileLocation.FullPath, e);
}
}
}
}