61 lines
1.8 KiB
C++
61 lines
1.8 KiB
C++
// parseobject.h
|
|
//
|
|
// Copyright (C) 2004 Chris Laurel <claurel@shatters.net>
|
|
//
|
|
// Functions for parsing objects common to star, solar system, and
|
|
// deep sky catalogs.
|
|
//
|
|
// This program 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 2
|
|
// of the License, or (at your option) any later version.
|
|
|
|
#ifndef _CELENGINE_PARSEOBJECT_H_
|
|
#define _CELENGINE_PARSEOBJECT_H_
|
|
|
|
#include <string>
|
|
#include <memory>
|
|
#include <celephem/orbit.h>
|
|
#include <celephem/rotation.h>
|
|
#include <celcompat/filesystem.h>
|
|
#include "frame.h"
|
|
#include "parser.h"
|
|
|
|
class Body;
|
|
class Star;
|
|
class Universe;
|
|
class Selection;
|
|
|
|
enum class DataDisposition
|
|
{
|
|
Add,
|
|
Modify,
|
|
Replace
|
|
};
|
|
|
|
|
|
bool ParseDate(Hash* hash, const std::string& name, double& jd);
|
|
|
|
Orbit* CreateOrbit(const Selection& centralObject,
|
|
Hash* planetData,
|
|
const fs::path& path,
|
|
bool usePlanetUnits);
|
|
|
|
RotationModel* CreateRotationModel(Hash* rotationData,
|
|
const fs::path& path,
|
|
double syncRotationPeriod);
|
|
|
|
RotationModel* CreateDefaultRotationModel(double syncRotationPeriod);
|
|
|
|
ReferenceFrame::SharedConstPtr CreateReferenceFrame(const Universe& universe,
|
|
Value* frameValue,
|
|
const Selection& defaultCenter,
|
|
Body* defaultObserver);
|
|
|
|
std::shared_ptr<const TwoVectorFrame> CreateTopocentricFrame(const Selection& center,
|
|
const Selection& target,
|
|
const Selection& observer);
|
|
|
|
|
|
#endif // _CELENGINE_PARSEOBJECT_H_
|