mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 18:10:21 -04:00 
			
		
		
		
	Re-enabling the WSJT-X i18n facilities. This allows translation files to be created for languages that are automatically used to lookup translatable strings. To enable a new language the language name must be added to the CMakeLists.txt LANGUAGES list variable in BCP47 format (i.e. en_US, en_GB, pt_PT, ...). Do one build with the CMake option UPDATE_TRANSLATIONS enabled (do not leave it enabled as there is a danger of loosing existing translated texts), that will create a fresh translations/wsjtx_<lang>.ts file which should be immediately checked in with the CMakeLists.txt change. The .ts should then be updated by the translator using the Qt Linguist tool to add translations. Check in the updated .ts file to complete the initial translation process for that language. To aid translators their WIP .ts file may be tested by releasing (using the lrelease tool or from the Linguist menu) a .qm file and placing that .qm file in the current directory before starting WSJT-X. The translations will be used if the system locale matches the file name. If the system locale does not match the file name; the language may be overridden by setting the LANG environment variable. For example if a wsjtx_pt_PT.qm file is in the current directory WSJT-X will use it for translation lookups, regardless of the current system locale setting, if the LANG variable is set to pt_PT or pt-PT. On MS Windows from a command prompt: set LANG=pt_PT C:\WSJT\wsjtx\bin\wsjtx elsewhere: LANG=pt_PT wsjtx
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef BANDS_HPP__
 | |
| #define BANDS_HPP__
 | |
| 
 | |
| #include <QAbstractTableModel>
 | |
| 
 | |
| #include "Radio.hpp"
 | |
| 
 | |
| //
 | |
| // Class Bands
 | |
| //
 | |
| //  Encapsulates information  about amateur radio bands  as defined by
 | |
| //  the  ADIF specification.  The model  is immutable.   The rows  are
 | |
| //  stored in asscending order of frequency.
 | |
| //
 | |
| // Responsibilities
 | |
| //
 | |
| //  Provides  a  well  known  band  name mapped  to  lower  and  upper
 | |
| //  frequency  limits.   Also  provides  a  convenience  operation  to
 | |
| //  determine the  band name  for any given  frequency, the  result of
 | |
| //  which may  be null  if the  given frequency  doesn't lie  within a
 | |
| //  recognised band.
 | |
| //
 | |
| // Collaborations
 | |
| //
 | |
| //  Implements the QAbstractTableModel interface as an immutable table
 | |
| //  where rows  are bands and  columns are band name,  lower frequency
 | |
| //  limit and, upper ferquency limit respectively.
 | |
| //
 | |
| class Bands final
 | |
|   : public QAbstractTableModel
 | |
| {
 | |
|   Q_OBJECT
 | |
| 
 | |
| public:
 | |
|   using Frequency = Radio::Frequency;
 | |
| 
 | |
|   // an iterator that meets the requirements of the C++ for range statement
 | |
|   class const_iterator
 | |
|   {
 | |
|   public:
 | |
|     const_iterator (int row)
 | |
|       : row_ {row}
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     QString operator * ();
 | |
|     bool operator != (const_iterator const&) const;
 | |
|     const_iterator& operator ++ ();
 | |
| 
 | |
|   private:
 | |
|     int row_;
 | |
|   };
 | |
| 
 | |
|   explicit Bands (QObject * parent = nullptr);
 | |
| 
 | |
|   //
 | |
|   // Model API
 | |
|   //
 | |
|   QString find (Frequency) const; // find band Frequency is in
 | |
|   int find (QString const&) const; // find row of band (-1 if not valid)
 | |
|   static QString const& oob ();
 | |
| 
 | |
|   // Iterators
 | |
|   const_iterator begin () const;
 | |
|   const_iterator end () const;
 | |
| 
 | |
|   // Custom role for sorting.
 | |
|   static int constexpr SortRole = Qt::UserRole;
 | |
| 
 | |
|   // Implement the QAbstractTableModel interface
 | |
|   int rowCount (QModelIndex const& parent = QModelIndex {}) const override;
 | |
|   int columnCount (QModelIndex const& parent = QModelIndex {}) const override;
 | |
|   Qt::ItemFlags flags (QModelIndex const& = QModelIndex {}) const override;
 | |
|   QVariant headerData (int section, Qt::Orientation, int = Qt::DisplayRole) const override;
 | |
| 
 | |
|   // The value return for the Qt::DisplayRole role for the root of the
 | |
|   // model (invalid index) is a special string representing out of
 | |
|   // band.
 | |
|   //
 | |
|   // All columns return a number for the custom role SortRole, this
 | |
|   // number defines a strict frequency order for the rows.
 | |
|   QVariant data (QModelIndex const&, int role = Qt::DisplayRole) const override;
 | |
| };
 | |
| 
 | |
| #endif
 |