mirror of
				https://github.com/Tha14/toxic.git
				synced 2025-10-26 11:36:47 +01:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			ugly_defin
			...
			bump_versi
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 58161b9ccc | 
							
								
								
									
										13
									
								
								.cirrus.yml
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								.cirrus.yml
									
									
									
									
									
								
							| @@ -1,13 +0,0 @@ | |||||||
| --- |  | ||||||
| cirrus-ci_task: |  | ||||||
|   container: |  | ||||||
|     image: toxchat/toktok-stack:0.0.23-third_party |  | ||||||
|     cpu: 2 |  | ||||||
|     memory: 2G |  | ||||||
|   configure_script: |  | ||||||
|     - /src/workspace/tools/inject-repo toxic |  | ||||||
|   test_all_script: |  | ||||||
|     - cd /src/workspace && bazel test -k |  | ||||||
|         --remote_http_cache=http://$CIRRUS_HTTP_CACHE_HOST |  | ||||||
|         --config=release |  | ||||||
|         //toxic/... |  | ||||||
							
								
								
									
										7
									
								
								.github/settings.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/settings.yml
									
									
									
									
										vendored
									
									
								
							| @@ -11,8 +11,7 @@ branches: | |||||||
|     protection: |     protection: | ||||||
|       required_status_checks: |       required_status_checks: | ||||||
|         contexts: |         contexts: | ||||||
|           - build |           - Codacy/PR Quality Review | ||||||
|           - cirrus-ci |           - CodeFactor | ||||||
|           - Codacy Static Code Analysis |           - Travis CI - Pull Request | ||||||
|           - code-review/reviewable |           - code-review/reviewable | ||||||
|           - infer |  | ||||||
|   | |||||||
							
								
								
									
										106
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										106
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,106 +0,0 @@ | |||||||
| name: ci |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: [master] |  | ||||||
|   pull_request: |  | ||||||
|     branches: [master] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   build: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v2 |  | ||||||
|       - name: Install dependencies |  | ||||||
|         run: |  | ||||||
|           sudo apt-get update && |  | ||||||
|           sudo apt-get install -y --no-install-recommends |  | ||||||
|             libalut-dev |  | ||||||
|             libconfig-dev |  | ||||||
|             libcurl4-gnutls-dev |  | ||||||
|             libnotify-dev |  | ||||||
|             libopenal-dev |  | ||||||
|             libopus-dev |  | ||||||
|             libqrencode-dev |  | ||||||
|             libsodium-dev |  | ||||||
|             libvpx-dev |  | ||||||
|             libx11-dev |  | ||||||
|             python3-dev |  | ||||||
|             pkg-config && |  | ||||||
|           git clone --depth=1 https://github.com/TokTok/c-toxcore && |  | ||||||
|           cd c-toxcore && |  | ||||||
|           cmake . -B_build -DBOOTSTRAP_DAEMON=OFF && |  | ||||||
|           cd _build && |  | ||||||
|           make -j4 && |  | ||||||
|           sudo make install |  | ||||||
|  |  | ||||||
|       - name: Build toxic |  | ||||||
|         run: make -j4 |  | ||||||
|  |  | ||||||
|   infer: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     container: toxchat/infer |  | ||||||
|     steps: |  | ||||||
|       - name: Install git |  | ||||||
|         run: |  | ||||||
|           apt-get update && |  | ||||||
|           DEBIAN_FRONTEND=noninteractive |  | ||||||
|           apt-get install -y --no-install-recommends |  | ||||||
|             git |  | ||||||
|       - name: Install dependencies |  | ||||||
|         run: |  | ||||||
|           apt-get update && |  | ||||||
|           apt-get install -y --no-install-recommends |  | ||||||
|             cmake |  | ||||||
|             g++ |  | ||||||
|             libalut-dev |  | ||||||
|             libconfig-dev |  | ||||||
|             libcurl4-gnutls-dev |  | ||||||
|             libncurses-dev |  | ||||||
|             libnotify-dev |  | ||||||
|             libopenal-dev |  | ||||||
|             libopus-dev |  | ||||||
|             libqrencode-dev |  | ||||||
|             libsodium-dev |  | ||||||
|             libvpx-dev |  | ||||||
|             libx11-dev |  | ||||||
|             make |  | ||||||
|             python3-dev |  | ||||||
|             pkg-config && |  | ||||||
|           git clone --depth=1 https://github.com/TokTok/c-toxcore && |  | ||||||
|           cd c-toxcore && |  | ||||||
|           cmake . -B_build -DBOOTSTRAP_DAEMON=OFF && |  | ||||||
|           cd _build && |  | ||||||
|           make -j4 && |  | ||||||
|           make install |  | ||||||
|       - uses: actions/checkout@v2 |  | ||||||
|  |  | ||||||
|       - name: Run infer |  | ||||||
|         run: |  | ||||||
|           infer --no-progress-bar -- cc src/*.c |  | ||||||
|             -fsyntax-only |  | ||||||
|             $(python3-config --includes --ldflags) |  | ||||||
|             $(pkg-config --cflags --libs |  | ||||||
|               freealut |  | ||||||
|               libconfig |  | ||||||
|               libcurl |  | ||||||
|               libnotify |  | ||||||
|               libpng |  | ||||||
|               libqrencode |  | ||||||
|               ncurses |  | ||||||
|               openal |  | ||||||
|               python3 |  | ||||||
|               toxcore |  | ||||||
|               vpx |  | ||||||
|               x11) |  | ||||||
|             -DAUDIO |  | ||||||
|             -DBOX_NOTIFY |  | ||||||
|             -DGAMES |  | ||||||
|             -DPACKAGE_DATADIR='""' |  | ||||||
|             -DPYTHON |  | ||||||
|             -DQRCODE |  | ||||||
|             -DSOUND_NOTIFY |  | ||||||
|             -DVIDEO |  | ||||||
|       - name: Print log |  | ||||||
|         run: |  | ||||||
|           cat /__w/toxic/toxic/infer-out/report.txt |  | ||||||
							
								
								
									
										60
									
								
								.travis.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								.travis.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | |||||||
|  | --- | ||||||
|  | language: python | ||||||
|  | python: nightly | ||||||
|  | dist: xenial | ||||||
|  | os: linux | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   include: | ||||||
|  |     - env: JOB=linux | ||||||
|  |  | ||||||
|  |       addons: | ||||||
|  |         apt: | ||||||
|  |           packages: | ||||||
|  |             - libalut-dev | ||||||
|  |             - libconfig-dev | ||||||
|  |             - libnotify-dev | ||||||
|  |             - libopenal-dev | ||||||
|  |             - libopus-dev | ||||||
|  |             - libqrencode-dev | ||||||
|  |             - libvpx-dev | ||||||
|  |  | ||||||
|  |       cache: | ||||||
|  |         directories: | ||||||
|  |           - $HOME/cache | ||||||
|  |  | ||||||
|  |       install: | ||||||
|  |         # Where to find libraries. | ||||||
|  |         - export LD_LIBRARY_PATH=$HOME/cache/usr/lib | ||||||
|  |         - export PKG_CONFIG_PATH=$HOME/cache/usr/lib/pkgconfig | ||||||
|  |         # c-sodium | ||||||
|  |         - git clone --depth=1 --branch=stable https://github.com/jedisct1/libsodium ../libsodium | ||||||
|  |         - test -f $HOME/cache/usr/lib/libsodium.so || (cd ../libsodium && ./configure --prefix=$HOME/cache/usr && make install -j$(nproc)) | ||||||
|  |         # c-toxcore | ||||||
|  |         - git clone --depth=1 https://github.com/TokTok/c-toxcore ../c-toxcore | ||||||
|  |         - test -f $HOME/cache/usr/lib/libtoxcore.so || (cd ../c-toxcore && cmake -B_build -H. -DCMAKE_INSTALL_PREFIX:PATH=$HOME/cache/usr && make -C_build install -j$(nproc)) | ||||||
|  |  | ||||||
|  |       script: | ||||||
|  |         - make ENABLE_PYTHON=1 -j$(nproc) | ||||||
|  |  | ||||||
|  |     - env: JOB=macos | ||||||
|  |       os: macos | ||||||
|  |       language: c | ||||||
|  |  | ||||||
|  |       cache: | ||||||
|  |         directories: | ||||||
|  |           - $HOME/cache | ||||||
|  |  | ||||||
|  |       install: | ||||||
|  |         - brew install | ||||||
|  |           freealut | ||||||
|  |           libconfig | ||||||
|  |           libqrencode | ||||||
|  |           libsodium | ||||||
|  |           openal-soft | ||||||
|  |         - export LDFLAGS="-L/usr/local/Cellar/openal-soft/1.21.0/lib" | ||||||
|  |         - git clone --depth=1 https://github.com/TokTok/c-toxcore ../c-toxcore | ||||||
|  |         - test -f /usr/local/lib/libtoxcore.dylib || (cd ../c-toxcore && cmake -B_build -H. && make -C_build install -j$(nproc)) | ||||||
|  |  | ||||||
|  |       script: | ||||||
|  |         - make ENABLE_PYTHON=1 DISABLE_DESKTOP_NOTIFY=1 DISABLE_X11=1 DISABLE_AV=1 DISABLE_SOUND_NOTIFY=1 -j$(nproc) | ||||||
| @@ -18,7 +18,6 @@ cc_binary( | |||||||
|     copts = [ |     copts = [ | ||||||
|         "-std=gnu99", |         "-std=gnu99", | ||||||
|         "-DAUDIO", |         "-DAUDIO", | ||||||
|         "-DGAMES", |  | ||||||
|         "-DPACKAGE_DATADIR='\"data\"'", |         "-DPACKAGE_DATADIR='\"data\"'", | ||||||
|         "-DPYTHON", |         "-DPYTHON", | ||||||
|         "-DQRCODE", |         "-DQRCODE", | ||||||
| @@ -40,10 +39,3 @@ cc_binary( | |||||||
|         "//tools/config:osx": [], |         "//tools/config:osx": [], | ||||||
|     }), |     }), | ||||||
| ) | ) | ||||||
|  |  | ||||||
| sh_test( |  | ||||||
|     name = "toxic_test", |  | ||||||
|     srcs = [":toxic"], |  | ||||||
|     args = ["--help"], |  | ||||||
|     size = "small", |  | ||||||
| ) |  | ||||||
|   | |||||||
| @@ -132,10 +132,10 @@ mkdir -p "$BUILD_DIR" | |||||||
| cd "$BUILD_DIR" | cd "$BUILD_DIR" | ||||||
|  |  | ||||||
| # The git hash of the c-toxcore version we're using | # The git hash of the c-toxcore version we're using | ||||||
| TOXCORE_VERSION="af1848ed13d2aa3a7fc218de1d0633e99814efec" | TOXCORE_VERSION="25a56c354937e9c8c4c50a64c3b4cfc099c34e29" | ||||||
|  |  | ||||||
| # The sha256sum of the c-toxcore tarball for TOXCORE_VERSION | # The sha256sum of the c-toxcore tarball for TOXCORE_VERSION | ||||||
| TOXCORE_HASH="acd1117b752583eb7d97aabc1053275ffa5f92591e166687a17c7267201a2e18" | TOXCORE_HASH="8448752e6286c747130254571fde2db8e2fc073a8116f9fff489ed53af546c0a" | ||||||
|  |  | ||||||
| TOXCORE_FILENAME="c-toxcore-$TOXCORE_VERSION.tar.gz" | TOXCORE_FILENAME="c-toxcore-$TOXCORE_VERSION.tar.gz" | ||||||
|  |  | ||||||
| @@ -164,8 +164,8 @@ cmake --build _build --target install | |||||||
| # location with SSL_CERT_FILE env variable. | # location with SSL_CERT_FILE env variable. | ||||||
| cd "$BUILD_DIR" | cd "$BUILD_DIR" | ||||||
|  |  | ||||||
| CURL_VERSION="7.80.0" | CURL_VERSION="7.77.0" | ||||||
| CURL_HASH="dab997c9b08cb4a636a03f2f7f985eaba33279c1c52692430018fae4a4878dc7" | CURL_HASH="b0a3428acb60fa59044c4d0baae4e4fc09ae9af1d8a3aa84b2e3fbcd99841f77" | ||||||
| CURL_FILENAME="curl-$CURL_VERSION.tar.gz" | CURL_FILENAME="curl-$CURL_VERSION.tar.gz" | ||||||
|  |  | ||||||
| wget --timeout=10 -O "$CURL_FILENAME" "https://curl.haxx.se/download/$CURL_FILENAME" | wget --timeout=10 -O "$CURL_FILENAME" "https://curl.haxx.se/download/$CURL_FILENAME" | ||||||
|   | |||||||
| @@ -41,6 +41,9 @@ Tox              *user_tox; | |||||||
| static WINDOW    *cur_window; | static WINDOW    *cur_window; | ||||||
| static ToxWindow *self_window; | static ToxWindow *self_window; | ||||||
|  |  | ||||||
|  | extern FriendsList Friends; | ||||||
|  | extern struct user_settings *user_settings; | ||||||
|  |  | ||||||
| void api_display(const char *const msg) | void api_display(const char *const msg) | ||||||
| { | { | ||||||
|     if (msg == NULL) { |     if (msg == NULL) { | ||||||
|   | |||||||
| @@ -60,8 +60,14 @@ | |||||||
| #endif /* ALC_ALL_DEVICES_SPECIFIER */ | #endif /* ALC_ALL_DEVICES_SPECIFIER */ | ||||||
| #endif /* __APPLE__ */ | #endif /* __APPLE__ */ | ||||||
|  |  | ||||||
|  | extern FriendsList Friends; | ||||||
|  | extern ToxWindow *windows[MAX_WINDOWS_NUM]; | ||||||
|  |  | ||||||
| struct CallControl CallControl; | struct CallControl CallControl; | ||||||
|  |  | ||||||
|  | extern struct user_settings *user_settings; | ||||||
|  | extern struct Winthread Winthread; | ||||||
|  |  | ||||||
| void on_call(ToxAV *av, uint32_t friend_number, bool audio_enabled, bool video_enabled, | void on_call(ToxAV *av, uint32_t friend_number, bool audio_enabled, bool video_enabled, | ||||||
|              void *user_data); |              void *user_data); | ||||||
| void on_call_state(ToxAV *av, uint32_t friend_number, uint32_t state, void *user_data); | void on_call_state(ToxAV *av, uint32_t friend_number, uint32_t state, void *user_data); | ||||||
|   | |||||||
| @@ -530,7 +530,7 @@ static DeviceError open_device(DeviceType type, uint32_t *device_idx, DataHandle | |||||||
|         device->cb_data = cb_data; |         device->cb_data = cb_data; | ||||||
| #ifdef AUDIO | #ifdef AUDIO | ||||||
|  |  | ||||||
|         if (user_settings->VAD_threshold >= 0.0) { |         if (user_settings->VAD_threshold >= 0.0f) { | ||||||
|             device->VAD_threshold = user_settings->VAD_threshold; |             device->VAD_threshold = user_settings->VAD_threshold; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -56,7 +56,7 @@ static void print_ac_matches(ToxWindow *self, Tox *m, char **list, size_t n_matc | |||||||
|  * |  * | ||||||
|  * Returns the length of the match. |  * Returns the length of the match. | ||||||
|  */ |  */ | ||||||
| static size_t get_str_match(ToxWindow *self, char *match, size_t match_sz, const char *const *matches, size_t n_items, | static size_t get_str_match(ToxWindow *self, char *match, size_t match_sz, const char **matches, size_t n_items, | ||||||
|                             size_t max_size) |                             size_t max_size) | ||||||
| { | { | ||||||
|     UNUSED_VAR(self); |     UNUSED_VAR(self); | ||||||
| @@ -96,7 +96,7 @@ static size_t get_str_match(ToxWindow *self, char *match, size_t match_sz, const | |||||||
|  * |  * | ||||||
|  * Note: This function should not be called directly. Use complete_line() and complete_path() instead. |  * Note: This function should not be called directly. Use complete_line() and complete_path() instead. | ||||||
|  */ |  */ | ||||||
| static int complete_line_helper(ToxWindow *self, const char *const *list, const size_t n_items, bool dir_search) | static int complete_line_helper(ToxWindow *self, const char **list, const size_t n_items, bool dir_search) | ||||||
| { | { | ||||||
|     ChatContext *ctx = self->chatwin; |     ChatContext *ctx = self->chatwin; | ||||||
|  |  | ||||||
| @@ -181,7 +181,7 @@ static int complete_line_helper(ToxWindow *self, const char *const *list, const | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     char match[MAX_STR_SIZE]; |     char match[MAX_STR_SIZE]; | ||||||
|     size_t match_len = get_str_match(self, match, sizeof(match), (const char *const *) matches, n_matches, MAX_STR_SIZE); |     size_t match_len = get_str_match(self, match, sizeof(match), (const char **) matches, n_matches, MAX_STR_SIZE); | ||||||
|  |  | ||||||
|     free_ptr_array((void **) matches); |     free_ptr_array((void **) matches); | ||||||
|  |  | ||||||
| @@ -259,12 +259,12 @@ static int complete_line_helper(ToxWindow *self, const char *const *list, const | |||||||
|     return diff; |     return diff; | ||||||
| } | } | ||||||
|  |  | ||||||
| int complete_line(ToxWindow *self, const char *const *list, size_t n_items) | int complete_line(ToxWindow *self, const char **list, size_t n_items) | ||||||
| { | { | ||||||
|     return complete_line_helper(self, list, n_items, false); |     return complete_line_helper(self, list, n_items, false); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int complete_path(ToxWindow *self, const char *const *list, const size_t n_items) | static int complete_path(ToxWindow *self, const char **list, const size_t n_items) | ||||||
| { | { | ||||||
|     return complete_line_helper(self, list, n_items, true); |     return complete_line_helper(self, list, n_items, true); | ||||||
| } | } | ||||||
| @@ -385,7 +385,7 @@ int dir_match(ToxWindow *self, Tox *m, const wchar_t *line, const wchar_t *cmd) | |||||||
|         print_ac_matches(self, m, dirnames, dircount); |         print_ac_matches(self, m, dirnames, dircount); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     int ret = complete_path(self, (const char *const *) dirnames, dircount); |     int ret = complete_path(self, (const char **) dirnames, dircount); | ||||||
|  |  | ||||||
|     free_ptr_array((void **) dirnames); |     free_ptr_array((void **) dirnames); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -39,7 +39,9 @@ | |||||||
| #include "settings.h" | #include "settings.h" | ||||||
| #include "windows.h" | #include "windows.h" | ||||||
|  |  | ||||||
|  | extern struct arg_opts arg_opts; | ||||||
| extern struct user_settings *user_settings; | extern struct user_settings *user_settings; | ||||||
|  | extern struct Winthread Winthread; | ||||||
|  |  | ||||||
| /* URL that we get the JSON encoded nodes list from. */ | /* URL that we get the JSON encoded nodes list from. */ | ||||||
| #define NODES_LIST_URL "https://nodes.tox.chat/json" | #define NODES_LIST_URL "https://nodes.tox.chat/json" | ||||||
| @@ -57,6 +59,7 @@ extern struct user_settings *user_settings; | |||||||
|  |  | ||||||
| #define IP_MAX_SIZE 45 | #define IP_MAX_SIZE 45 | ||||||
| #define IP_MIN_SIZE 7 | #define IP_MIN_SIZE 7 | ||||||
|  | #define PORT_MAX_SIZE 5 | ||||||
|  |  | ||||||
| #define LAST_SCAN_JSON_KEY "\"last_scan\":" | #define LAST_SCAN_JSON_KEY "\"last_scan\":" | ||||||
| #define LAST_SCAN_JSON_KEY_LEN (sizeof(LAST_SCAN_JSON_KEY) - 1) | #define LAST_SCAN_JSON_KEY_LEN (sizeof(LAST_SCAN_JSON_KEY) - 1) | ||||||
|   | |||||||
							
								
								
									
										74
									
								
								src/chat.c
									
									
									
									
									
								
							
							
						
						
									
										74
									
								
								src/chat.c
									
									
									
									
									
								
							| @@ -58,6 +58,12 @@ | |||||||
| #endif /* VIDEO */ | #endif /* VIDEO */ | ||||||
| #endif /* AUDIO */ | #endif /* AUDIO */ | ||||||
|  |  | ||||||
|  | extern char *DATA_FILE; | ||||||
|  | extern FriendsList Friends; | ||||||
|  |  | ||||||
|  | extern struct Winthread Winthread; | ||||||
|  | extern struct user_settings *user_settings; | ||||||
|  |  | ||||||
| #ifdef AUDIO | #ifdef AUDIO | ||||||
| static void init_infobox(ToxWindow *self); | static void init_infobox(ToxWindow *self); | ||||||
| static void kill_infobox(ToxWindow *self); | static void kill_infobox(ToxWindow *self); | ||||||
| @@ -792,7 +798,12 @@ void chat_onGameInvite(ToxWindow *self, Tox *m, uint32_t friend_number, const ui | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     Friends.list[friend_number].game_invite.type = type; | ||||||
|  |     Friends.list[friend_number].game_invite.id = id; | ||||||
|  |     Friends.list[friend_number].game_invite.pending = true; | ||||||
|  |  | ||||||
|     uint32_t data_length = length - GAME_PACKET_HEADER_SIZE; |     uint32_t data_length = length - GAME_PACKET_HEADER_SIZE; | ||||||
|  |     Friends.list[friend_number].game_invite.data_length = data_length; | ||||||
|  |  | ||||||
|     if (data_length > 0) { |     if (data_length > 0) { | ||||||
|         free(Friends.list[friend_number].game_invite.data); |         free(Friends.list[friend_number].game_invite.data); | ||||||
| @@ -807,11 +818,6 @@ void chat_onGameInvite(ToxWindow *self, Tox *m, uint32_t friend_number, const ui | |||||||
|         Friends.list[friend_number].game_invite.data = buf; |         Friends.list[friend_number].game_invite.data = buf; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     Friends.list[friend_number].game_invite.type = type; |  | ||||||
|     Friends.list[friend_number].game_invite.id = id; |  | ||||||
|     Friends.list[friend_number].game_invite.pending = true; |  | ||||||
|     Friends.list[friend_number].game_invite.data_length = data_length; |  | ||||||
|  |  | ||||||
|     char name[TOX_MAX_NAME_LENGTH]; |     char name[TOX_MAX_NAME_LENGTH]; | ||||||
|     get_nick_truncate(m, name, friend_number); |     get_nick_truncate(m, name, friend_number); | ||||||
|  |  | ||||||
| @@ -1264,16 +1270,9 @@ static void chat_onDraw(ToxWindow *self, Tox *m) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     ChatContext *ctx = self->chatwin; |     ChatContext *ctx = self->chatwin; | ||||||
|     StatusBar *statusbar = self->stb; |  | ||||||
|  |  | ||||||
|     pthread_mutex_lock(&Winthread.lock); |     pthread_mutex_lock(&Winthread.lock); | ||||||
|  |  | ||||||
|     line_info_print(self); |     line_info_print(self); | ||||||
|  |  | ||||||
|     Tox_Connection connection = statusbar->connection; |  | ||||||
|     Tox_User_Status status = statusbar->status; |  | ||||||
|     const bool is_typing = Friends.list[self->num].is_typing; |  | ||||||
|  |  | ||||||
|     pthread_mutex_unlock(&Winthread.lock); |     pthread_mutex_unlock(&Winthread.lock); | ||||||
|  |  | ||||||
|     wclear(ctx->linewin); |     wclear(ctx->linewin); | ||||||
| @@ -1284,6 +1283,14 @@ static void chat_onDraw(ToxWindow *self, Tox *m) | |||||||
|  |  | ||||||
|     curs_set(1); |     curs_set(1); | ||||||
|  |  | ||||||
|  |     /* Draw status bar */ | ||||||
|  |     StatusBar *statusbar = self->stb; | ||||||
|  |  | ||||||
|  |     pthread_mutex_lock(&Winthread.lock); | ||||||
|  |     Tox_Connection connection = statusbar->connection; | ||||||
|  |     Tox_User_Status status = statusbar->status; | ||||||
|  |     pthread_mutex_unlock(&Winthread.lock); | ||||||
|  |  | ||||||
|     wmove(statusbar->topline, 0, 0); |     wmove(statusbar->topline, 0, 0); | ||||||
|  |  | ||||||
|     wattron(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); |     wattron(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); | ||||||
| @@ -1311,13 +1318,13 @@ static void chat_onDraw(ToxWindow *self, Tox *m) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     wattron(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); |     wattron(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); | ||||||
|     wprintw(statusbar->topline, "] "); |     wprintw(statusbar->topline, "]"); | ||||||
|     wattroff(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); |     wattroff(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); | ||||||
|  |  | ||||||
|     const char *status_text = "ERROR"; |     if (status != TOX_USER_STATUS_NONE) { | ||||||
|     int colour = BAR_TEXT; |         const char *status_text = "ERROR"; | ||||||
|  |         int colour = MAGENTA; | ||||||
|  |  | ||||||
|     if (connection != TOX_CONNECTION_NONE) { |  | ||||||
|         switch (status) { |         switch (status) { | ||||||
|             case TOX_USER_STATUS_AWAY: |             case TOX_USER_STATUS_AWAY: | ||||||
|                 colour = STATUS_AWAY; |                 colour = STATUS_AWAY; | ||||||
| @@ -1332,11 +1339,9 @@ static void chat_onDraw(ToxWindow *self, Tox *m) | |||||||
|             default: |             default: | ||||||
|                 break; |                 break; | ||||||
|         } |         } | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (colour != BAR_TEXT) { |  | ||||||
|         wattron(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); |         wattron(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); | ||||||
|         wprintw(statusbar->topline, "["); |         wprintw(statusbar->topline, " ["); | ||||||
|         wattroff(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); |         wattroff(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); | ||||||
|  |  | ||||||
|         wattron(statusbar->topline, COLOR_PAIR(colour) | A_BOLD); |         wattron(statusbar->topline, COLOR_PAIR(colour) | A_BOLD); | ||||||
| @@ -1346,23 +1351,30 @@ static void chat_onDraw(ToxWindow *self, Tox *m) | |||||||
|         wattron(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); |         wattron(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); | ||||||
|         wprintw(statusbar->topline, "] "); |         wprintw(statusbar->topline, "] "); | ||||||
|         wattroff(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); |         wattroff(statusbar->topline, COLOR_PAIR(BAR_ACCENT)); | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (is_typing) { |         pthread_mutex_lock(&Winthread.lock); | ||||||
|         wattron(statusbar->topline, A_BOLD | COLOR_PAIR(BAR_NOTIFY)); |         const bool is_typing = Friends.list[self->num].is_typing; | ||||||
|  |         pthread_mutex_unlock(&Winthread.lock); | ||||||
|  |  | ||||||
|  |         if (is_typing) { | ||||||
|  |             wattron(statusbar->topline, A_BOLD | COLOR_PAIR(BAR_NOTIFY)); | ||||||
|  |         } else { | ||||||
|  |             wattron(statusbar->topline, COLOR_PAIR(BAR_TEXT)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         wprintw(statusbar->topline, "%s", statusbar->nick); | ||||||
|  |  | ||||||
|  |         if (is_typing) { | ||||||
|  |             wattroff(statusbar->topline, A_BOLD | COLOR_PAIR(BAR_NOTIFY)); | ||||||
|  |         } else { | ||||||
|  |             wattroff(statusbar->topline, A_BOLD | COLOR_PAIR(BAR_TEXT)); | ||||||
|  |         } | ||||||
|     } else { |     } else { | ||||||
|         wattron(statusbar->topline, COLOR_PAIR(BAR_TEXT)); |         wattron(statusbar->topline, COLOR_PAIR(BAR_TEXT)); | ||||||
|  |         wprintw(statusbar->topline, " %s", statusbar->nick); | ||||||
|  |         wattroff(statusbar->topline, COLOR_PAIR(BAR_TEXT)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     wprintw(statusbar->topline, "%s", statusbar->nick); |  | ||||||
|  |  | ||||||
|     if (is_typing) { |  | ||||||
|         wattroff(statusbar->topline, A_BOLD | COLOR_PAIR(BAR_NOTIFY)); |  | ||||||
|     } else { |  | ||||||
|         wattroff(statusbar->topline, A_BOLD | COLOR_PAIR(BAR_TEXT)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /* Reset statusbar->statusmsg on window resize */ |     /* Reset statusbar->statusmsg on window resize */ | ||||||
|     if (x2 != self->x) { |     if (x2 != self->x) { | ||||||
|         char statusmsg[TOX_MAX_STATUS_MESSAGE_LENGTH] = {'\0'}; |         char statusmsg[TOX_MAX_STATUS_MESSAGE_LENGTH] = {'\0'}; | ||||||
|   | |||||||
| @@ -63,6 +63,8 @@ | |||||||
| #include "toxic_strings.h" | #include "toxic_strings.h" | ||||||
| #include "windows.h" | #include "windows.h" | ||||||
|  |  | ||||||
|  | extern char *DATA_FILE; | ||||||
|  |  | ||||||
| #define MAX_CONFERENCE_NUM (MAX_WINDOWS_NUM - 2) | #define MAX_CONFERENCE_NUM (MAX_WINDOWS_NUM - 2) | ||||||
| #define CONFERENCE_EVENT_WAIT 30 | #define CONFERENCE_EVENT_WAIT 30 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -117,8 +117,15 @@ static struct cmd_func conference_commands[] = { | |||||||
|     { NULL,         NULL             }, |     { NULL,         NULL             }, | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #ifdef PYTHON | ||||||
|  | #define SPECIAL_COMMANDS 8 | ||||||
|  | #else | ||||||
|  | #define SPECIAL_COMMANDS 7 | ||||||
|  | #endif /* PYTHON */ | ||||||
|  |  | ||||||
| /* Special commands are commands that only take one argument even if it contains spaces */ | /* Special commands are commands that only take one argument even if it contains spaces */ | ||||||
| static const char special_commands[][MAX_CMDNAME_SIZE] = { | static const char special_commands[SPECIAL_COMMANDS][MAX_CMDNAME_SIZE] = { | ||||||
|     "/add", |     "/add", | ||||||
|     "/avatar", |     "/avatar", | ||||||
|     "/nick", |     "/nick", | ||||||
| @@ -129,7 +136,6 @@ static const char special_commands[][MAX_CMDNAME_SIZE] = { | |||||||
|     "/sendfile", |     "/sendfile", | ||||||
|     "/title", |     "/title", | ||||||
|     "/mute", |     "/mute", | ||||||
|     "", |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /* Returns true if input command is in the special_commands array. */ | /* Returns true if input command is in the special_commands array. */ | ||||||
| @@ -137,7 +143,7 @@ static bool is_special_command(const char *input) | |||||||
| { | { | ||||||
|     const int s = char_find(0, input, ' '); |     const int s = char_find(0, input, ' '); | ||||||
|  |  | ||||||
|     for (int i = 0; special_commands[i][0] != '\0'; ++i) { |     for (int i = 0; i < SPECIAL_COMMANDS; ++i) { | ||||||
|         if (strncmp(input, special_commands[i], s) == 0) { |         if (strncmp(input, special_commands[i], s) == 0) { | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -37,7 +37,6 @@ | |||||||
| #include "log.h" | #include "log.h" | ||||||
| #include "misc_tools.h" | #include "misc_tools.h" | ||||||
| #include "notify.h" | #include "notify.h" | ||||||
| #include "prompt.h" |  | ||||||
| #include "settings.h" | #include "settings.h" | ||||||
| #include "toxic.h" | #include "toxic.h" | ||||||
| #include "windows.h" | #include "windows.h" | ||||||
| @@ -47,6 +46,13 @@ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|  | extern char *DATA_FILE; | ||||||
|  | extern char *BLOCK_FILE; | ||||||
|  | extern ToxWindow *prompt; | ||||||
|  | extern struct Winthread Winthread; | ||||||
|  | extern struct user_settings *user_settings; | ||||||
|  | extern struct arg_opts arg_opts; | ||||||
|  |  | ||||||
| static uint8_t blocklist_view = 0;   /* 0 if we're in friendlist view, 1 if we're in blocklist view */ | static uint8_t blocklist_view = 0;   /* 0 if we're in friendlist view, 1 if we're in blocklist view */ | ||||||
|  |  | ||||||
| FriendsList Friends; | FriendsList Friends; | ||||||
| @@ -315,11 +321,11 @@ int load_blocklist(char *path) | |||||||
| #define S_WEIGHT 100000 | #define S_WEIGHT 100000 | ||||||
| static int index_name_cmp(const void *n1, const void *n2) | static int index_name_cmp(const void *n1, const void *n2) | ||||||
| { | { | ||||||
|     int res = qsort_strcasecmp_hlpr(Friends.list[*(const int *) n1].name, Friends.list[*(const int *) n2].name); |     int res = qsort_strcasecmp_hlpr(Friends.list[*(int *) n1].name, Friends.list[*(int *) n2].name); | ||||||
|  |  | ||||||
|     /* Use weight to make qsort always put online friends before offline */ |     /* Use weight to make qsort always put online friends before offline */ | ||||||
|     res = Friends.list[*(const int *) n1].connection_status ? (res - S_WEIGHT) : (res + S_WEIGHT); |     res = Friends.list[*(int *) n1].connection_status ? (res - S_WEIGHT) : (res + S_WEIGHT); | ||||||
|     res = Friends.list[*(const int *) n2].connection_status ? (res + S_WEIGHT) : (res - S_WEIGHT); |     res = Friends.list[*(int *) n2].connection_status ? (res + S_WEIGHT) : (res - S_WEIGHT); | ||||||
|  |  | ||||||
|     return res; |     return res; | ||||||
| } | } | ||||||
| @@ -343,7 +349,7 @@ void sort_friendlist_index(void) | |||||||
|  |  | ||||||
| static int index_name_cmp_block(const void *n1, const void *n2) | static int index_name_cmp_block(const void *n1, const void *n2) | ||||||
| { | { | ||||||
|     return qsort_strcasecmp_hlpr(Blocked.list[*(const int *) n1].name, Blocked.list[*(const int *) n2].name); |     return qsort_strcasecmp_hlpr(Blocked.list[*(int *) n1].name, Blocked.list[*(int *) n2].name); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void sort_blocklist_index(void) | static void sort_blocklist_index(void) | ||||||
|   | |||||||
| @@ -101,8 +101,6 @@ typedef struct { | |||||||
|     ToxicFriend *list; |     ToxicFriend *list; | ||||||
| } FriendsList; | } FriendsList; | ||||||
|  |  | ||||||
| extern FriendsList Friends; |  | ||||||
|  |  | ||||||
| ToxWindow *new_friendlist(void); | ToxWindow *new_friendlist(void); | ||||||
| void friendlist_onInit(ToxWindow *self, Tox *m); | void friendlist_onInit(ToxWindow *self, Tox *m); | ||||||
| void disable_chatwin(uint32_t f_num); | void disable_chatwin(uint32_t f_num); | ||||||
|   | |||||||
| @@ -517,10 +517,10 @@ static void game_draw_help_bar(const GameData *game, WINDOW *win) | |||||||
| { | { | ||||||
|     int max_x; |     int max_x; | ||||||
|     int max_y; |     int max_y; | ||||||
|     getmaxyx(win, max_y, max_x); |  | ||||||
|  |  | ||||||
|     UNUSED_VAR(max_x); |     UNUSED_VAR(max_x); | ||||||
|  |  | ||||||
|  |     getmaxyx(win, max_y, max_x); | ||||||
|  |  | ||||||
|     wmove(win, max_y - 1, 1); |     wmove(win, max_y - 1, 1); | ||||||
|  |  | ||||||
|     if (!game->is_multiplayer) { |     if (!game->is_multiplayer) { | ||||||
| @@ -937,10 +937,10 @@ int game_y_bottom_bound(const GameData *game) | |||||||
| { | { | ||||||
|     int max_x; |     int max_x; | ||||||
|     int max_y; |     int max_y; | ||||||
|     getmaxyx(game->window, max_y, max_x); |  | ||||||
|  |  | ||||||
|     UNUSED_VAR(max_x); |     UNUSED_VAR(max_x); | ||||||
|  |  | ||||||
|  |     getmaxyx(game->window, max_y, max_x); | ||||||
|  |  | ||||||
|     return ((max_y + game->game_max_y) / 2) - 1; |     return ((max_y + game->game_max_y) / 2) - 1; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -948,10 +948,10 @@ int game_y_top_bound(const GameData *game) | |||||||
| { | { | ||||||
|     int max_x; |     int max_x; | ||||||
|     int max_y; |     int max_y; | ||||||
|     getmaxyx(game->window, max_y, max_x); |  | ||||||
|  |  | ||||||
|     UNUSED_VAR(max_x); |     UNUSED_VAR(max_x); | ||||||
|  |  | ||||||
|  |     getmaxyx(game->window, max_y, max_x); | ||||||
|  |  | ||||||
|     return ((max_y - game->game_max_y) / 2) + 1; |     return ((max_y - game->game_max_y) / 2) + 1; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -959,10 +959,10 @@ int game_x_right_bound(const GameData *game) | |||||||
| { | { | ||||||
|     int max_x; |     int max_x; | ||||||
|     int max_y; |     int max_y; | ||||||
|     getmaxyx(game->window, max_y, max_x); |  | ||||||
|  |  | ||||||
|     UNUSED_VAR(max_y); |     UNUSED_VAR(max_y); | ||||||
|  |  | ||||||
|  |     getmaxyx(game->window, max_y, max_x); | ||||||
|  |  | ||||||
|     return ((max_x + game->game_max_x) / 2) - 1; |     return ((max_x + game->game_max_x) / 2) - 1; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -970,10 +970,10 @@ int game_x_left_bound(const GameData *game) | |||||||
| { | { | ||||||
|     int max_x; |     int max_x; | ||||||
|     int max_y; |     int max_y; | ||||||
|     getmaxyx(game->window, max_y, max_x); |  | ||||||
|  |  | ||||||
|     UNUSED_VAR(max_y); |     UNUSED_VAR(max_y); | ||||||
|  |  | ||||||
|  |     getmaxyx(game->window, max_y, max_x); | ||||||
|  |  | ||||||
|     return ((max_x - game->game_max_x) / 2) + 1; |     return ((max_x - game->game_max_x) / 2) + 1; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -436,11 +436,7 @@ static bool chess_path_line_clear(Board *board, const Tile *from, const Tile *to | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     ChessCoords chess_coords = (ChessCoords) { |     ChessCoords chess_coords; | ||||||
|         0, |  | ||||||
|         0 |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     size_t start; |     size_t start; | ||||||
|     size_t end; |     size_t end; | ||||||
|  |  | ||||||
| @@ -804,13 +800,11 @@ static bool chess_mock_move_valid(ChessState *state, const Player *player, Tile | |||||||
| { | { | ||||||
|     Board *board = &state->board; |     Board *board = &state->board; | ||||||
|  |  | ||||||
|     const bool en_passant = player->en_passant_move_number == -1; |  | ||||||
|     bool in_check = false; |     bool in_check = false; | ||||||
|     Tile *ep_tile = NULL; |     Tile *ep_tile = NULL; | ||||||
|     Piece ep_piece; |     Piece ep_piece; | ||||||
|     memset(&ep_piece, 0, sizeof(ep_piece)); |  | ||||||
|  |  | ||||||
|     if (en_passant) {  // remove piece that was captured via en passant |     if (player->en_passant_move_number == -1) {  // remove piece that was captured via en passant | ||||||
|         ChessCoords ep_coords; |         ChessCoords ep_coords; | ||||||
|         ep_coords.N = player->colour == White ? to->chess_coords.N - 1 : to->chess_coords.N + 1; |         ep_coords.N = player->colour == White ? to->chess_coords.N - 1 : to->chess_coords.N + 1; | ||||||
|         ep_coords.L = to->chess_coords.L; |         ep_coords.L = to->chess_coords.L; | ||||||
| @@ -821,7 +815,7 @@ static bool chess_mock_move_valid(ChessState *state, const Player *player, Tile | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         chess_copy_piece(&ep_piece, &ep_tile->piece); |         chess_copy_piece(&ep_piece, &ep_tile->piece); | ||||||
|         ep_tile->piece.type = NoPiece;  // temporarily remove piece |         ep_tile->piece.type = NoPiece; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     Piece from_piece; |     Piece from_piece; | ||||||
| @@ -837,8 +831,8 @@ static bool chess_mock_move_valid(ChessState *state, const Player *player, Tile | |||||||
|     from->piece.type = from_piece.type; |     from->piece.type = from_piece.type; | ||||||
|     chess_copy_piece(&to->piece, &to_piece); |     chess_copy_piece(&to->piece, &to_piece); | ||||||
|  |  | ||||||
|     if (en_passant) { |     if (player->en_passant_move_number == -1) { | ||||||
|         ep_tile->piece.type = ep_piece.type;  // reset piece to original state |         ep_tile->piece.type = ep_piece.type; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return !in_check; |     return !in_check; | ||||||
|   | |||||||
| @@ -42,6 +42,11 @@ | |||||||
| #include "game_base.h" | #include "game_base.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | extern char *DATA_FILE; | ||||||
|  | extern ToxWindow *prompt; | ||||||
|  | extern FriendsList Friends; | ||||||
|  | extern FriendRequests FrndRequests; | ||||||
|  |  | ||||||
| /* command functions */ | /* command functions */ | ||||||
| void cmd_accept(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE]) | void cmd_accept(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE]) | ||||||
| { | { | ||||||
| @@ -156,12 +161,18 @@ void cmd_add(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX | |||||||
|  |  | ||||||
|     const char *id = argv[1]; |     const char *id = argv[1]; | ||||||
|     const size_t arg_length = strlen(id); |     const size_t arg_length = strlen(id); | ||||||
|     const int space_idx = char_find(0, id, ' '); |     const bool is_tox_id = arg_length >= (2 * TOX_ADDRESS_SIZE); | ||||||
|  |  | ||||||
|     // we have to manually parse the message due to this command being a special case |     if (is_tox_id) { | ||||||
|     if (space_idx > 0 && space_idx < arg_length - 1) { |         // we have to manually parse the message due to this command being a special case | ||||||
|         snprintf(msg, sizeof(msg), "%s", &id[space_idx + 1]); |         int idx = char_find(0, id, ' '); | ||||||
|     } else { |  | ||||||
|  |         if (idx > 0 && idx < arg_length - 1) { | ||||||
|  |             snprintf(msg, sizeof(msg), "%s", &id[idx + 1]); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (!msg[0]) { | ||||||
|         char selfname[TOX_MAX_NAME_LENGTH]; |         char selfname[TOX_MAX_NAME_LENGTH]; | ||||||
|         tox_self_get_name(m, (uint8_t *) selfname); |         tox_self_get_name(m, (uint8_t *) selfname); | ||||||
|  |  | ||||||
| @@ -172,34 +183,34 @@ void cmd_add(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX | |||||||
|  |  | ||||||
|     char id_bin[TOX_ADDRESS_SIZE] = {0}; |     char id_bin[TOX_ADDRESS_SIZE] = {0}; | ||||||
|  |  | ||||||
|     const bool is_tox_id = (char_find(0, id, '@') == arg_length) && (arg_length >= TOX_ADDRESS_SIZE * 2); |     /* try to add tox ID */ | ||||||
|  |     if (is_tox_id) { | ||||||
|  |         size_t i; | ||||||
|  |         char xx[3]; | ||||||
|  |         uint32_t x; | ||||||
|  |  | ||||||
|     if (!is_tox_id) { |         for (i = 0; i < TOX_ADDRESS_SIZE; ++i) { | ||||||
|         name_lookup(self, m, id_bin, id, msg); |             xx[0] = id[2 * i]; | ||||||
|     } |             xx[1] = id[2 * i + 1]; | ||||||
|  |             xx[2] = 0; | ||||||
|  |  | ||||||
|     char xx[3]; |             if (sscanf(xx, "%02x", &x) != 1) { | ||||||
|     uint32_t x = 0; |                 line_info_add(self, false, NULL, NULL, SYS_MSG, 0, 0, "Invalid Tox ID."); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|     for (size_t i = 0; i < TOX_ADDRESS_SIZE; ++i) { |             id_bin[i] = x; | ||||||
|         xx[0] = id[2 * i]; |         } | ||||||
|         xx[1] = id[2 * i + 1]; |  | ||||||
|         xx[2] = 0; |  | ||||||
|  |  | ||||||
|         if (sscanf(xx, "%02x", &x) != 1) { |         if (friend_is_blocked(id_bin)) { | ||||||
|             line_info_add(self, false, NULL, NULL, SYS_MSG, 0, 0, "Invalid Tox ID."); |             line_info_add(self, false, NULL, NULL, SYS_MSG, 0, 0, "Friend is in your block list."); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         id_bin[i] = x; |         cmd_add_helper(self, m, id_bin, msg); | ||||||
|  |     } else {    /* assume id is a username@domain address and do http name server lookup */ | ||||||
|  |         name_lookup(self, m, id_bin, id, msg); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (friend_is_blocked(id_bin)) { |  | ||||||
|         line_info_add(self, false, NULL, NULL, SYS_MSG, 0, 0, "Friend is in your block list."); |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     cmd_add_helper(self, m, id_bin, msg); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void cmd_avatar(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE]) | void cmd_avatar(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE]) | ||||||
|   | |||||||
| @@ -148,9 +148,8 @@ static int print_n_chars(WINDOW *win, const char *s, size_t n, int max_y) | |||||||
|  |  | ||||||
|             int x; |             int x; | ||||||
|             int y; |             int y; | ||||||
|             getyx(win, y, x); |  | ||||||
|  |  | ||||||
|             UNUSED_VAR(x); |             UNUSED_VAR(x); | ||||||
|  |             getyx(win, y, x); | ||||||
|  |  | ||||||
|             // make sure cursor will wrap correctly after newline to prevent display bugs |             // make sure cursor will wrap correctly after newline to prevent display bugs | ||||||
|             if (y + 1 >= max_y) { |             if (y + 1 >= max_y) { | ||||||
| @@ -325,10 +324,10 @@ static void line_info_init_line(ToxWindow *self, struct line_info *line) | |||||||
| { | { | ||||||
|     int y2; |     int y2; | ||||||
|     int x2; |     int x2; | ||||||
|     getmaxyx(self->window, y2, x2); |  | ||||||
|  |  | ||||||
|     UNUSED_VAR(y2); |     UNUSED_VAR(y2); | ||||||
|  |  | ||||||
|  |     getmaxyx(self->window, y2, x2); | ||||||
|  |  | ||||||
|     const int max_y = y2 - CHATBOX_HEIGHT - WINDOW_BAR_HEIGHT; |     const int max_y = y2 - CHATBOX_HEIGHT - WINDOW_BAR_HEIGHT; | ||||||
|     const int max_x = self->show_peerlist ? x2 - 1 - SIDEBAR_WIDTH : x2; |     const int max_x = self->show_peerlist ? x2 - 1 - SIDEBAR_WIDTH : x2; | ||||||
|  |  | ||||||
| @@ -523,10 +522,10 @@ void line_info_print(ToxWindow *self) | |||||||
|     while (line && numlines++ <= max_y && print_ret == 0) { |     while (line && numlines++ <= max_y && print_ret == 0) { | ||||||
|         int y; |         int y; | ||||||
|         int x; |         int x; | ||||||
|         getyx(win, y, x); |  | ||||||
|  |  | ||||||
|         UNUSED_VAR(y); |         UNUSED_VAR(y); | ||||||
|  |  | ||||||
|  |         getyx(win, y, x); | ||||||
|  |  | ||||||
|         if (x > 0) { // Prevents us from printing off the screen |         if (x > 0) { // Prevents us from printing off the screen | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -148,7 +148,7 @@ void get_elapsed_time_str(char *buf, int bufsize, time_t secs) | |||||||
|  */ |  */ | ||||||
| int tox_pk_string_to_bytes(const char *hex_string, size_t hex_len, char *output, size_t output_size) | int tox_pk_string_to_bytes(const char *hex_string, size_t hex_len, char *output, size_t output_size) | ||||||
| { | { | ||||||
|     if (output_size != TOX_PUBLIC_KEY_SIZE || hex_len != output_size * 2) { |     if (output_size != TOX_PUBLIC_KEY_SIZE || hex_len > output_size * 2) { | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -288,7 +288,7 @@ int qsort_strcasecmp_hlpr(const void *str1, const void *str2) | |||||||
| /* case-insensitive string compare function for use with qsort */ | /* case-insensitive string compare function for use with qsort */ | ||||||
| int qsort_ptr_char_array_helper(const void *str1, const void *str2) | int qsort_ptr_char_array_helper(const void *str1, const void *str2) | ||||||
| { | { | ||||||
|     return strcasecmp(*(const char *const *)str1, *(const char *const *)str2); |     return strcasecmp(*(char **)str1, *(char **)str2); | ||||||
| } | } | ||||||
|  |  | ||||||
| static const char invalid_chars[] = {'/', '\n', '\t', '\v', '\r', '\0'}; | static const char invalid_chars[] = {'/', '\n', '\t', '\v', '\r', '\0'}; | ||||||
|   | |||||||
| @@ -33,6 +33,9 @@ | |||||||
| #include "toxic.h" | #include "toxic.h" | ||||||
| #include "windows.h" | #include "windows.h" | ||||||
|  |  | ||||||
|  | extern struct arg_opts arg_opts; | ||||||
|  | extern struct Winthread Winthread; | ||||||
|  |  | ||||||
| #define NAMESERVER_API_PATH "api" | #define NAMESERVER_API_PATH "api" | ||||||
| #define SERVER_KEY_SIZE 32 | #define SERVER_KEY_SIZE 32 | ||||||
| #define MAX_SERVERS 50 | #define MAX_SERVERS 50 | ||||||
| @@ -108,15 +111,14 @@ static int load_nameserver_list(const char *path) | |||||||
|     char line[MAX_SERVER_LINE]; |     char line[MAX_SERVER_LINE]; | ||||||
|  |  | ||||||
|     while (fgets(line, sizeof(line), fp) && Nameservers.lines < MAX_SERVERS) { |     while (fgets(line, sizeof(line), fp) && Nameservers.lines < MAX_SERVERS) { | ||||||
|         size_t linelen = strlen(line); |         int linelen = strlen(line); | ||||||
|  |  | ||||||
|         if (linelen < SERVER_KEY_SIZE * 2 + 5) { |         if (linelen < SERVER_KEY_SIZE * 2 + 5) { | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (line[linelen - 1] == '\n') { |         if (line[linelen - 1] == '\n') { | ||||||
|             --linelen; |             line[--linelen] = '\0'; | ||||||
|             line[linelen] = '\0'; |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         const char *name = strtok(line, " "); |         const char *name = strtok(line, " "); | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								src/notify.c
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								src/notify.c
									
									
									
									
									
								
							| @@ -489,27 +489,16 @@ void terminate_notify(void) | |||||||
| } | } | ||||||
|  |  | ||||||
| #ifdef SOUND_NOTIFY | #ifdef SOUND_NOTIFY | ||||||
|  | int set_sound(Notification sound, const char *value) | ||||||
| /* |  | ||||||
|  * Sets notification sound designated by `sound` to file path `value`. |  | ||||||
|  * |  | ||||||
|  * Return true if the sound is successfully set. |  | ||||||
|  */ |  | ||||||
| bool set_sound(Notification sound, const char *value) |  | ||||||
| { | { | ||||||
|     if (sound == silent) { |     if (sound == silent) { | ||||||
|         return false; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     free(Control.sounds[sound]); |     free(Control.sounds[sound]); | ||||||
|  |  | ||||||
|     size_t len = strlen(value) + 1; |     size_t len = strlen(value) + 1; | ||||||
|     Control.sounds[sound] = calloc(len, 1); |     Control.sounds[sound] = calloc(len, 1); | ||||||
|  |  | ||||||
|     if (Control.sounds[sound] == NULL) { |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     memcpy(Control.sounds[sound], value, len); |     memcpy(Control.sounds[sound], value, len); | ||||||
|  |  | ||||||
|     struct stat buf; |     struct stat buf; | ||||||
|   | |||||||
| @@ -77,7 +77,7 @@ int box_silent_notify(ToxWindow *self, uint64_t flags, int *id_indicator, const | |||||||
| int box_silent_notify2(ToxWindow *self, uint64_t flags, int id, const char *format, ...); | int box_silent_notify2(ToxWindow *self, uint64_t flags, int id, const char *format, ...); | ||||||
|  |  | ||||||
| #ifdef SOUND_NOTIFY | #ifdef SOUND_NOTIFY | ||||||
| bool set_sound(Notification sound, const char *value); | int set_sound(Notification sound, const char *value); | ||||||
| #endif /* SOUND_NOTIFY */ | #endif /* SOUND_NOTIFY */ | ||||||
|  |  | ||||||
| #endif /* NOTIFY_H */ | #endif /* NOTIFY_H */ | ||||||
|   | |||||||
| @@ -40,9 +40,6 @@ typedef struct FriendRequests { | |||||||
|     struct friend_request request[MAX_FRIEND_REQUESTS]; |     struct friend_request request[MAX_FRIEND_REQUESTS]; | ||||||
| } FriendRequests; | } FriendRequests; | ||||||
|  |  | ||||||
| extern ToxWindow *prompt; |  | ||||||
| extern FriendRequests FrndRequests; |  | ||||||
|  |  | ||||||
| ToxWindow *new_prompt(void); | ToxWindow *new_prompt(void); | ||||||
|  |  | ||||||
| void prep_prompt_win(void); | void prep_prompt_win(void); | ||||||
|   | |||||||
| @@ -96,8 +96,6 @@ struct user_settings { | |||||||
| #endif | #endif | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern struct user_settings *user_settings; |  | ||||||
|  |  | ||||||
| enum settings_values { | enum settings_values { | ||||||
|     AUTOLOG_OFF = 0, |     AUTOLOG_OFF = 0, | ||||||
|     AUTOLOG_ON = 1, |     AUTOLOG_ON = 1, | ||||||
|   | |||||||
| @@ -74,7 +74,7 @@ | |||||||
| #ifdef VIDEO | #ifdef VIDEO | ||||||
| #include "video_call.h" | #include "video_call.h" | ||||||
| #endif /* VIDEO */ | #endif /* VIDEO */ | ||||||
| static ToxAV *av; | ToxAV *av; | ||||||
| #endif /* AUDIO */ | #endif /* AUDIO */ | ||||||
|  |  | ||||||
| #ifdef PYTHON | #ifdef PYTHON | ||||||
| @@ -98,13 +98,10 @@ ToxWindow *prompt = NULL; | |||||||
| #define MAX_PASSWORD_LEN 64 | #define MAX_PASSWORD_LEN 64 | ||||||
|  |  | ||||||
| struct Winthread Winthread; | struct Winthread Winthread; | ||||||
| static struct cqueue_thread cqueue_thread; | struct cqueue_thread cqueue_thread; | ||||||
|  | struct av_thread av_thread; | ||||||
| struct arg_opts arg_opts; | struct arg_opts arg_opts; | ||||||
|  |  | ||||||
| #ifdef AUDIO |  | ||||||
| static struct av_thread av_thread; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| // This struct is not thread safe. It should only ever be written to from the main thread | // This struct is not thread safe. It should only ever be written to from the main thread | ||||||
| // before any other thread that uses it is initialized. | // before any other thread that uses it is initialized. | ||||||
| struct user_settings *user_settings = NULL; | struct user_settings *user_settings = NULL; | ||||||
|   | |||||||
| @@ -145,7 +145,5 @@ void on_friend_typing(Tox *m, uint32_t friendnumber, bool is_typing, void *userd | |||||||
| void on_friend_read_receipt(Tox *m, uint32_t friendnumber, uint32_t receipt, void *userdata); | void on_friend_read_receipt(Tox *m, uint32_t friendnumber, uint32_t receipt, void *userdata); | ||||||
| void on_lossless_custom_packet(Tox *m, uint32_t friendnumber, const uint8_t *data, size_t length, void *userdata); | void on_lossless_custom_packet(Tox *m, uint32_t friendnumber, const uint8_t *data, size_t length, void *userdata); | ||||||
|  |  | ||||||
| extern char *DATA_FILE; |  | ||||||
| extern char *BLOCK_FILE; |  | ||||||
|  |  | ||||||
| #endif /* TOXIC_H */ | #endif /* TOXIC_H */ | ||||||
|   | |||||||
| @@ -92,21 +92,21 @@ typedef struct VideoDevice { | |||||||
|  |  | ||||||
| } VideoDevice; | } VideoDevice; | ||||||
|  |  | ||||||
| static const char *dvideo_device_names[2];        /* Default device */ | const char *dvideo_device_names[2];              /* Default device */ | ||||||
| static char *video_devices_names[2][MAX_DEVICES]; /* Container of available devices */ | const char *video_devices_names[2][MAX_DEVICES]; /* Container of available devices */ | ||||||
| static int size[2];                               /* Size of above containers */ | static int size[2];                        /* Size of above containers */ | ||||||
| static VideoDevice *video_devices_running[2][MAX_DEVICES] = {{NULL}}; /* Running devices */ | VideoDevice *video_devices_running[2][MAX_DEVICES] = {{NULL}};     /* Running devices */ | ||||||
| static uint32_t primary_video_device[2];                              /* Primary device */ | uint32_t primary_video_device[2];          /* Primary device */ | ||||||
|  |  | ||||||
| static ToxAV *av = NULL; | static ToxAV *av = NULL; | ||||||
|  |  | ||||||
| /* q_mutex */ | /* q_mutex */ | ||||||
| #define lock pthread_mutex_lock(&video_mutex) | #define lock pthread_mutex_lock(&video_mutex) | ||||||
| #define unlock pthread_mutex_unlock(&video_mutex) | #define unlock pthread_mutex_unlock(&video_mutex) | ||||||
| static pthread_mutex_t video_mutex; | pthread_mutex_t video_mutex; | ||||||
|  |  | ||||||
| static bool video_thread_running = true; | bool video_thread_running = true, | ||||||
| static bool video_thread_paused = true;                /* Thread control */ |      video_thread_paused = true;                /* Thread control */ | ||||||
|  |  | ||||||
| void *video_thread_poll(void *); | void *video_thread_poll(void *); | ||||||
|  |  | ||||||
| @@ -187,7 +187,7 @@ VideoDeviceError init_video_devices(void) | |||||||
|  |  | ||||||
| #if defined(__OSX__) || defined(__APPLE__) | #if defined(__OSX__) || defined(__APPLE__) | ||||||
|  |  | ||||||
|     if (osx_video_init(&video_devices_names[vdt_input][0], &size[vdt_input]) != 0) { |     if (osx_video_init((char **)video_devices_names[vdt_input], &size[vdt_input]) != 0) { | ||||||
|         return vde_InternalError; |         return vde_InternalError; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -209,24 +209,12 @@ VideoDeviceError init_video_devices(void) | |||||||
|             /* Query V4L for capture capabilities */ |             /* Query V4L for capture capabilities */ | ||||||
|             if (-1 != ioctl(fd, VIDIOC_QUERYCAP, &cap)) { |             if (-1 != ioctl(fd, VIDIOC_QUERYCAP, &cap)) { | ||||||
|                 video_input_name = (char *)malloc(strlen((const char *)cap.card) + strlen(device_address) + 4); |                 video_input_name = (char *)malloc(strlen((const char *)cap.card) + strlen(device_address) + 4); | ||||||
|  |  | ||||||
|                 if (video_input_name == NULL) { |  | ||||||
|                     close(fd); |  | ||||||
|                     return vde_InternalError; |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 strcpy(video_input_name, (char *)cap.card); |                 strcpy(video_input_name, (char *)cap.card); | ||||||
|                 strcat(video_input_name, " ("); |                 strcat(video_input_name, " ("); | ||||||
|                 strcat(video_input_name, (char *)device_address); |                 strcat(video_input_name, (char *)device_address); | ||||||
|                 strcat(video_input_name, ")"); |                 strcat(video_input_name, ")"); | ||||||
|             } else { |             } else { | ||||||
|                 video_input_name = (char *)malloc(strlen(device_address) + 3); |                 video_input_name = (char *)malloc(strlen(device_address) + 3); | ||||||
|  |  | ||||||
|                 if (video_input_name == NULL) { |  | ||||||
|                     close(fd); |  | ||||||
|                     return vde_InternalError; |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 strcpy(video_input_name, "("); |                 strcpy(video_input_name, "("); | ||||||
|                 strcat(video_input_name, device_address); |                 strcat(video_input_name, device_address); | ||||||
|                 strcat(video_input_name, ")"); |                 strcat(video_input_name, ")"); | ||||||
| @@ -241,9 +229,6 @@ VideoDeviceError init_video_devices(void) | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
|     size[vdt_output] = 1; |     size[vdt_output] = 1; | ||||||
|     // TODO(iphydf): String literals are const char *. This may need to be |  | ||||||
|     // copied, or if we're not owning any output device names, it should be |  | ||||||
|     // const and video_devices_names needs to be split. |  | ||||||
|     char *video_output_name = "Toxic Video Receiver"; |     char *video_output_name = "Toxic Video Receiver"; | ||||||
|     video_devices_names[vdt_output][0] = video_output_name; |     video_devices_names[vdt_output][0] = video_output_name; | ||||||
|  |  | ||||||
| @@ -277,7 +262,7 @@ VideoDeviceError terminate_video_devices(void) | |||||||
|     int i; |     int i; | ||||||
|  |  | ||||||
|     for (i = 0; i < size[vdt_input]; ++i) { |     for (i = 0; i < size[vdt_input]; ++i) { | ||||||
|         free(video_devices_names[vdt_input][i]); |         free((void *)video_devices_names[vdt_input][i]); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (pthread_mutex_destroy(&video_mutex) != 0) { |     if (pthread_mutex_destroy(&video_mutex) != 0) { | ||||||
|   | |||||||
| @@ -41,10 +41,16 @@ | |||||||
| #include "game_base.h" | #include "game_base.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | extern char *DATA_FILE; | ||||||
|  | extern struct Winthread Winthread; | ||||||
|  |  | ||||||
| ToxWindow *windows[MAX_WINDOWS_NUM]; | ToxWindow *windows[MAX_WINDOWS_NUM]; | ||||||
| static uint8_t active_window_index; | static uint8_t active_window_index; | ||||||
| static int num_active_windows; | static int num_active_windows; | ||||||
|  |  | ||||||
|  | extern ToxWindow *prompt; | ||||||
|  | extern struct user_settings *user_settings; | ||||||
|  |  | ||||||
| /* CALLBACKS START */ | /* CALLBACKS START */ | ||||||
| void on_friend_request(Tox *m, const uint8_t *public_key, const uint8_t *data, size_t length, void *userdata) | void on_friend_request(Tox *m, const uint8_t *public_key, const uint8_t *data, size_t length, void *userdata) | ||||||
| { | { | ||||||
| @@ -190,7 +196,7 @@ void on_conference_invite(Tox *m, uint32_t friendnumber, Tox_Conference_Type typ | |||||||
|  |  | ||||||
|     for (uint8_t i = 0; i < MAX_WINDOWS_NUM; ++i) { |     for (uint8_t i = 0; i < MAX_WINDOWS_NUM; ++i) { | ||||||
|         if (windows[i] != NULL && windows[i]->onConferenceInvite != NULL) { |         if (windows[i] != NULL && windows[i]->onConferenceInvite != NULL) { | ||||||
|             windows[i]->onConferenceInvite(windows[i], m, friendnumber, type, (const char *) conference_pub_key, length); |             windows[i]->onConferenceInvite(windows[i], m, friendnumber, type, (char *) conference_pub_key, length); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -275,7 +281,7 @@ void on_file_recv_chunk(Tox *m, uint32_t friendnumber, uint32_t filenumber, uint | |||||||
|  |  | ||||||
|     for (uint8_t i = 0; i < MAX_WINDOWS_NUM; ++i) { |     for (uint8_t i = 0; i < MAX_WINDOWS_NUM; ++i) { | ||||||
|         if (windows[i] != NULL && windows[i]->onFileRecvChunk != NULL) { |         if (windows[i] != NULL && windows[i]->onFileRecvChunk != NULL) { | ||||||
|             windows[i]->onFileRecvChunk(windows[i], m, friendnumber, filenumber, position, (const char *) data, length); |             windows[i]->onFileRecvChunk(windows[i], m, friendnumber, filenumber, position, (char *) data, length); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -316,7 +322,7 @@ void on_file_recv(Tox *m, uint32_t friendnumber, uint32_t filenumber, uint32_t k | |||||||
|  |  | ||||||
|     for (uint8_t i = 0; i < MAX_WINDOWS_NUM; ++i) { |     for (uint8_t i = 0; i < MAX_WINDOWS_NUM; ++i) { | ||||||
|         if (windows[i] != NULL && windows[i]->onFileRecv != NULL) { |         if (windows[i] != NULL && windows[i]->onFileRecv != NULL) { | ||||||
|             windows[i]->onFileRecv(windows[i], m, friendnumber, filenumber, file_size, (const char *) filename, |             windows[i]->onFileRecv(windows[i], m, friendnumber, filenumber, file_size, (char *) filename, | ||||||
|                                    filename_length); |                                    filename_length); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -685,10 +691,10 @@ void draw_window_bar(ToxWindow *self) | |||||||
|  |  | ||||||
|     int cur_x; |     int cur_x; | ||||||
|     int cur_y; |     int cur_y; | ||||||
|     getyx(win, cur_y, cur_x); |  | ||||||
|  |  | ||||||
|     UNUSED_VAR(cur_y); |     UNUSED_VAR(cur_y); | ||||||
|  |  | ||||||
|  |     getyx(win, cur_y, cur_x); | ||||||
|  |  | ||||||
|     wattron(win, COLOR_PAIR(BAR_TEXT)); |     wattron(win, COLOR_PAIR(BAR_TEXT)); | ||||||
|     mvwhline(win, 0, cur_x, ' ', COLS - cur_x); |     mvwhline(win, 0, cur_x, ' ', COLS - cur_x); | ||||||
|     wattroff(win, COLOR_PAIR(BAR_TEXT)); |     wattroff(win, COLOR_PAIR(BAR_TEXT)); | ||||||
|   | |||||||
| @@ -114,8 +114,6 @@ struct Winthread { | |||||||
|     volatile sig_atomic_t last_refresh_flag; |     volatile sig_atomic_t last_refresh_flag; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern struct Winthread Winthread; |  | ||||||
|  |  | ||||||
| struct cqueue_thread { | struct cqueue_thread { | ||||||
|     pthread_t tid; |     pthread_t tid; | ||||||
| }; | }; | ||||||
| @@ -149,8 +147,6 @@ struct arg_opts { | |||||||
|     uint16_t tcp_port; |     uint16_t tcp_port; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern struct arg_opts arg_opts; |  | ||||||
|  |  | ||||||
| typedef struct ToxWindow ToxWindow; | typedef struct ToxWindow ToxWindow; | ||||||
| typedef struct StatusBar StatusBar; | typedef struct StatusBar StatusBar; | ||||||
| typedef struct PromptBuf PromptBuf; | typedef struct PromptBuf PromptBuf; | ||||||
| @@ -237,8 +233,6 @@ struct ToxWindow { | |||||||
|     WINDOW *window_bar; |     WINDOW *window_bar; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern ToxWindow *windows[MAX_WINDOWS_NUM]; |  | ||||||
|  |  | ||||||
| /* statusbar info holder */ | /* statusbar info holder */ | ||||||
| struct StatusBar { | struct StatusBar { | ||||||
|     WINDOW *topline; |     WINDOW *topline; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user