1 /*---------------------------------------------------------------------------*
2   Project:  Horizon
3   File:     pl_SharedFont.h
4 
5   Copyright (C)2010 Nintendo Co., Ltd.  All rights reserved.
6 
7   These coded instructions, statements, and computer programs contain
8   proprietary information of Nintendo of America Inc. and/or Nintendo
9   Company Ltd., and are protected by Federal copyright law.  They may
10   not be disclosed to third parties or copied or duplicated in any form,
11   in whole or in part, without the prior written consent of Nintendo.
12 
13   $Rev: 30100 $
14  *---------------------------------------------------------------------------*/
15 
16 #ifndef NN_PL_CTR_PL_SHAREDFONT_H_
17 #define NN_PL_CTR_PL_SHAREDFONT_H_
18 
19 #include <nn/Handle.h>
20 #include <nn/Result.h>
21 #include <nn/types.h>
22 #include <nn/fnd.h>
23 
24 namespace nn {
25 namespace pl {
26 namespace CTR {
27 
28 /*!
29     @name       共有フォント
30     @{
31  */
32 /*!
33     @brief  共有フォントの種類を表します。
34  */
35 enum SharedFontType
36 {
37     SHARED_FONT_TYPE_NULL,
38     SHARED_FONT_TYPE_STD,     //!< 日米欧フォント
39     SHARED_FONT_TYPE_CN,      //!< 中国フォント
40     SHARED_FONT_TYPE_KR,      //!< 韓国フォント
41     SHARED_FONT_TYPE_TW       //!< 台湾フォント
42 };
43 
44 /*!
45     @brief  共有フォントのロード状態を表します。
46  */
47 enum SharedFontLoadState
48 {
49     SHARED_FONT_LOAD_STATE_NULL,
50     SHARED_FONT_LOAD_STATE_LOADING,     //!< ロード中
51     SHARED_FONT_LOAD_STATE_LOADED,      //!< ロード済
52     SHARED_FONT_LOAD_STATE_FAILED,      //!< ロード失敗
53 
54     SHARED_FONT_LOAD_STATE_MAX_BIT = (1u << 31)
55 };
56 
57 namespace detail
58 {
59     // 共有フォント用共有メモリのサイズ: 3,272 KB
60     const size_t  SHAREDFONT_MEMORY_SIZE = 1024 * 4 * 818;
61 
62     struct SharedFontBufferHeader
63     {
64         util::SizedEnum4<SharedFontLoadState>   state;
65         util::SizedEnum4<SharedFontType>        type;
66         size_t                                  size;
67         bit8                                    padding[116];
68     };
69 
70     struct SharedFontBuffer
71     {
72         SharedFontBufferHeader  header;
73         // 128 byte アライメントが必要
74         bit8    font[SHAREDFONT_MEMORY_SIZE - sizeof(SharedFontBufferHeader)];
75     };
76 }
77 
78 /*!
79     @brief      共有フォントを使用可能にします。
80     @return     処理結果を返します。
81  */
82 nn::Result          InitializeSharedFont();
83 
84 /*!
85     @brief      共有フォントのアドレスを取得します。
86     @return     共有フォントのアドレスを返します。
87  */
88 void*               GetSharedFontAddress();
89 
90 /*!
91     @brief      共有フォントのサイズを取得します。
92     @return     共有フォントのサイズを返します。
93  */
94 size_t              GetSharedFontSize();
95 
96 /*!
97     @brief      共有フォントの種類を取得します。
98     @return     共有フォントの種類を返します。
99  */
100 SharedFontType      GetSharedFontType();
101 
102 /*!
103     @brief      共有フォントのロード状態を取得します。
104     @return     共有フォントのロード状態を返します。
105  */
106 SharedFontLoadState GetSharedFontLoadState();
107 
108 /*!
109     @brief      共有フォントのアーカイブをマウントします。
110 
111                 @ref GetSharedFontType で取得できるフォント以外のフォントを使用する場合は、
112                 アプリケーション自身がアーカイブをマウントしフォントファイルを開く必要があります。
113 
114                 アーカイブ内のフォントは以下に入っています。
115                 アーカイブ名を "font:"として開いた場合として説明します。
116 
117                 @li SHARED_FONT_TYPE_STD: "font:/cbf_std.bcfnt.lz"
118                 @li SHARED_FONT_TYPE_CN:  "font:/cbf_zh-Hans-CN.bcfnt.lz"
119                 @li SHARED_FONT_TYPE_KR:  "font:/cbf_ko-Hang-KR.bcfnt.lz"
120                 @li SHARED_FONT_TYPE_TW:  "font:/cbf_zh-Hant-TW.bcfnt.lz"
121 
122                 マウントに関連する引数は、他のマウント用インタフェースと同様です。
123 
124     @param[in]  archiveName         アーカイブの名前を指定します。(例: "fnt1:")
125     @param[in]  sharedFontType      共有フォントの種類を指定します。
126     @param[in]  maxFile             同時に開くファイル数を指定します。
127     @param[in]  maxDirectory        同時に開くディレクトリの数を指定します。
128     @param[in]  workingMemory       作業領域へのアドレスを指定します。
129     @param[in]  workingMemorySize   作業領域のサイズを指定します。
130 
131     @return     結果を返します。
132     @retval     nn::pl::ResultSharedFontNotFound    指定した共有フォントがありませんでした。
133 */
134 nn::Result MountSharedFont(const char* archiveName, SharedFontType sharedFontType, size_t maxFile, size_t maxDirectory, void* workingMemory, size_t workingMemorySize);
135 
136 /*!
137     @brief      共有フォントのアーカイブをアンマウントします。
138 
139     @param[in]  archiveName         マウントしたアーカイブの名前を指定します。
140 
141     @return     結果を返します。
142 */
143 nn::Result UnmountSharedFont(const char* archiveName);
144 
145 /*!
146     :private
147 
148     @brief pl ライブラリを初期化します。
149 */
150 inline void Initialize();
151 
Initialize()152 inline void Initialize() {}
153 
154 /*!
155     :private
156 
157     @brief pl ライブラリを終了します。
158 */
159 inline void Finalize();
160 
Finalize()161 inline void Finalize() {}
162 
163 /*!
164     @}
165  */
166 
167 } // end of namespace CTR
168 } // end of namespace pl
169 } // end of namespace nn
170 
171 
172 #endif  // ifndef NN_PL_CTR_PL_SHAREDFONT_H_
173