File indexing completed on 2024-09-08 03:28:59
0001 /* 0002 SPDX-FileCopyrightText: 2011 Akarsh Simha <akarshsimha@gmail.com> 0003 0004 SPDX-License-Identifier: GPL-2.0-or-later 0005 */ 0006 0007 #ifndef NOMADBINFILE2SQLITE_H 0008 #define NOMADBINFILE2SQLITE_H 0009 0010 #define pow2(x) (1 << (x)) 0011 #define HTM_LEVEL 6 0012 #define INDEX_ENTRY_SIZE 12 0013 #define NTRIXELS pow2(2 * HTM_LEVEL) * 8 0014 #define PM_MILLENIA 10 // This is not good. Needs to be stored in the data file 0015 0016 #include "HTMesh.h" 0017 0018 #include <sqlite3.h> 0019 #include <sys/types.h> 0020 #include <stdio.h> 0021 0022 /* 0023 * struct to store star data, to be written in this format, into the binary file. 0024 */ 0025 0026 typedef struct DeepStarData 0027 { 0028 int32_t RA; 0029 int32_t Dec; 0030 int16_t dRA; 0031 int16_t dDec; 0032 int16_t B; 0033 int16_t V; 0034 } DeepStarData; 0035 0036 /** 0037 *@class NOMADStarDataWriter 0038 *@short Writes NOMAD star data 0039 *@note This is ugly code, not part of the main KStars program 0040 *@author Akarsh Simha <akarsh.simha@kdemail.net> 0041 */ 0042 class NOMADStarDataWriter 0043 { 0044 public: 0045 /** 0046 *@short Constructor. Sets up the HTMesh, initializes various things. 0047 */ 0048 NOMADStarDataWriter(FILE *f, int HTMLevel, sqlite3 *_db, char *_db_tbl); 0049 0050 /** 0051 *@short Destructor. Deletes the HTMesh we created. 0052 */ 0053 ~NOMADStarDataWriter(); 0054 0055 /** 0056 *@short Byteswaps the DeepStarData structure 0057 */ 0058 static void bswap_stardata(DeepStarData *stardata); 0059 0060 /** 0061 *@short Computes the (unprecessed) coordinates of a star after 0062 * accounting for proper motion 0063 */ 0064 static void calculatePMCoords(double startRA, double startDec, double dRA, double dDec, double *endRA, 0065 double *endDec, float years); 0066 0067 /** 0068 *@short Writes the star data into the DB by calling multiple functions 0069 *@return Whether the write was successful 0070 */ 0071 bool write(); 0072 0073 private: 0074 /** 0075 *@short Creates the table to write data into 0076 */ 0077 bool createTable(); 0078 0079 /** 0080 *@short Truncates the table 0081 */ 0082 bool truncateTable(); 0083 0084 /** 0085 *@short Insert the star data into the database 0086 *@param trixel The trixel in which the star exists according to the data file 0087 *@param data The DeepStarData structure containing the star's information 0088 *@return true if inserted or star was a duplicate, false if an error occurred 0089 *@note This method takes care of duplicating the star and finding the number of copies 0090 */ 0091 bool insertStarData(unsigned int trixel, const DeepStarData *const data); 0092 0093 /** 0094 *@short Write star data into the DB 0095 *@note See README.binfileformat for more details 0096 */ 0097 bool writeStarDataToDB(); 0098 0099 /** 0100 *@short Read the KStars binary file header and gets various 0101 * parameters required for further processing. 0102 *@returns true on success. 0103 */ 0104 bool readFileHeader(); 0105 0106 HTMesh *m_Mesh; 0107 sqlite3 *db; 0108 char db_tbl[20]; 0109 bool byteswap; 0110 bool m_HeaderRead; 0111 long m_IndexOffset; 0112 u_int16_t ntrixels; 0113 FILE *DataFile; 0114 }; 0115 0116 #endif