tryed to find hang bug and finally realized it was cargo watch. however, now the app manages the tokio runtime manually, and only uses tokio for threading
This commit is contained in:
		
							parent
							
								
									0abcf8351a
								
							
						
					
					
						commit
						7b5ee1f397
					
				
							
								
								
									
										178
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										178
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @ -134,14 +134,13 @@ checksum = "5c6cb57a04249c6480766f7f7cef5467412af1490f8d1e243141daddada3264f" | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "alsa" | name = "alsa" | ||||||
| version = "0.7.0" | version = "0.9.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "8512c9117059663fb5606788fbca3619e2a91dac0e3fe516242eab1fa6be5e44" | checksum = "37fe60779335388a88c01ac6c3be40304d1e349de3ada3b15f7808bb90fa9dce" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "alsa-sys", |  "alsa-sys", | ||||||
|  "bitflags 1.3.2", |  "bitflags 2.5.0", | ||||||
|  "libc", |  "libc", | ||||||
|  "nix 0.24.3", |  | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -177,7 +176,7 @@ dependencies = [ | |||||||
|  "bitflags 2.5.0", |  "bitflags 2.5.0", | ||||||
|  "cc", |  "cc", | ||||||
|  "cesu8", |  "cesu8", | ||||||
|  "jni 0.21.1", |  "jni", | ||||||
|  "jni-sys", |  "jni-sys", | ||||||
|  "libc", |  "libc", | ||||||
|  "log", |  "log", | ||||||
| @ -1124,27 +1123,25 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "cpal" | name = "cpal" | ||||||
| version = "0.15.2" | version = "0.15.3" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "6d959d90e938c5493000514b446987c07aed46c668faaa7d34d6c7a67b1a578c" | checksum = "873dab07c8f743075e57f524c583985fbaf745602acbe916a01539364369a779" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "alsa", |  "alsa", | ||||||
|  "core-foundation-sys 0.8.4", |  "core-foundation-sys 0.8.4", | ||||||
|  "coreaudio-rs", |  "coreaudio-rs", | ||||||
|  "dasp_sample", |  "dasp_sample", | ||||||
|  "jni 0.19.0", |  "jni", | ||||||
|  "js-sys", |  "js-sys", | ||||||
|  "libc", |  "libc", | ||||||
|  "mach2", |  "mach2", | ||||||
|  "ndk 0.7.0", |  "ndk 0.8.0", | ||||||
|  "ndk-context", |  "ndk-context", | ||||||
|  "oboe", |  "oboe", | ||||||
|  "once_cell", |  | ||||||
|  "parking_lot 0.12.1", |  | ||||||
|  "wasm-bindgen", |  "wasm-bindgen", | ||||||
|  "wasm-bindgen-futures", |  "wasm-bindgen-futures", | ||||||
|  "web-sys", |  "web-sys", | ||||||
|  "windows 0.46.0", |  "windows 0.54.0", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -1306,24 +1303,24 @@ dependencies = [ | |||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "dirs-next" | name = "dirs" | ||||||
| version = "2.0.0" | version = "5.0.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "b98cf8ebf19c3d1b223e151f99a4f9f0690dca41414773390fc824184ac833e1" | checksum = "44c45a9d03d6676652bcb5e724c7e988de1acad23a711b5217ab9cbecbec2225" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if 1.0.0", |  "dirs-sys", | ||||||
|  "dirs-sys-next", |  | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "dirs-sys-next" | name = "dirs-sys" | ||||||
| version = "0.1.2" | version = "0.4.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "4ebda144c4fe02d1f7ea1a7d9641b6fc6b580adcfa024ae48797ecdeb6825b4d" | checksum = "520f05a5cbd335fae5a99ff7a6ab8627577660ee5cfd6a94a6a929b52ff0321c" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc", |  "libc", | ||||||
|  |  "option-ext", | ||||||
|  "redox_users", |  "redox_users", | ||||||
|  "winapi", |  "windows-sys 0.48.0", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -1371,6 +1368,12 @@ version = "1.2.1" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "75b325c5dbd37f80359721ad39aca5a29fb04c89279657cffdda8736d0c0b9d2" | checksum = "75b325c5dbd37f80359721ad39aca5a29fb04c89279657cffdda8736d0c0b9d2" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "dpi" | ||||||
|  | version = "0.1.1" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "f25c0e292a7ca6d6498557ff1df68f32c99850012b6ea401cf8daf771f22ff53" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "ecolor" | name = "ecolor" | ||||||
| version = "0.27.2" | version = "0.27.2" | ||||||
| @ -2407,34 +2410,6 @@ version = "1.0.9" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" | checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "jni" |  | ||||||
| version = "0.19.0" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "c6df18c2e3db7e453d3c6ac5b3e9d5182664d28788126d39b91f2d1e22b017ec" |  | ||||||
| dependencies = [ |  | ||||||
|  "cesu8", |  | ||||||
|  "combine", |  | ||||||
|  "jni-sys", |  | ||||||
|  "log", |  | ||||||
|  "thiserror", |  | ||||||
|  "walkdir", |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| [[package]] |  | ||||||
| name = "jni" |  | ||||||
| version = "0.20.0" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "039022cdf4d7b1cf548d31f60ae783138e5fd42013f6271049d7df7afadef96c" |  | ||||||
| dependencies = [ |  | ||||||
|  "cesu8", |  | ||||||
|  "combine", |  | ||||||
|  "jni-sys", |  | ||||||
|  "log", |  | ||||||
|  "thiserror", |  | ||||||
|  "walkdir", |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "jni" | name = "jni" | ||||||
| version = "0.21.1" | version = "0.21.1" | ||||||
| @ -2865,12 +2840,13 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "muda" | name = "muda" | ||||||
| version = "0.12.2" | version = "0.13.5" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "a40c16e25abca53b401d2972e8ad344820e318cf7e00ea8a951a5ca265590295" | checksum = "86b959f97c97044e4c96e32e1db292a7d594449546a3c6b77ae613dc3a5b5145" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cocoa 0.25.0", |  "cocoa 0.25.0", | ||||||
|  "crossbeam-channel", |  "crossbeam-channel", | ||||||
|  |  "dpi", | ||||||
|  "gtk", |  "gtk", | ||||||
|  "keyboard-types", |  "keyboard-types", | ||||||
|  "libxdo", |  "libxdo", | ||||||
| @ -2913,20 +2889,6 @@ dependencies = [ | |||||||
|  "thiserror", |  "thiserror", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "ndk" |  | ||||||
| version = "0.7.0" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "451422b7e4718271c8b5b3aadf5adedba43dc76312454b387e98fae0fc951aa0" |  | ||||||
| dependencies = [ |  | ||||||
|  "bitflags 1.3.2", |  | ||||||
|  "jni-sys", |  | ||||||
|  "ndk-sys 0.4.1+23.1.7779620", |  | ||||||
|  "num_enum 0.5.11", |  | ||||||
|  "raw-window-handle 0.5.2", |  | ||||||
|  "thiserror", |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "ndk" | name = "ndk" | ||||||
| version = "0.8.0" | version = "0.8.0" | ||||||
| @ -2982,15 +2944,6 @@ version = "0.2.2" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "e1bcdd74c20ad5d95aacd60ef9ba40fdf77f767051040541df557b7a9b2a2121" | checksum = "e1bcdd74c20ad5d95aacd60ef9ba40fdf77f767051040541df557b7a9b2a2121" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "ndk-sys" |  | ||||||
| version = "0.4.1+23.1.7779620" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "3cf2aae958bd232cac5069850591667ad422d263686d75b52a065f9badeee5a3" |  | ||||||
| dependencies = [ |  | ||||||
|  "jni-sys", |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "ndk-sys" | name = "ndk-sys" | ||||||
| version = "0.5.0+25.2.9519653" | version = "0.5.0+25.2.9519653" | ||||||
| @ -3024,17 +2977,6 @@ dependencies = [ | |||||||
|  "libc", |  "libc", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "nix" |  | ||||||
| version = "0.24.3" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "fa52e972a9a719cecb6864fb88568781eb706bac2cd1d4f04a648542dbf78069" |  | ||||||
| dependencies = [ |  | ||||||
|  "bitflags 1.3.2", |  | ||||||
|  "cfg-if 1.0.0", |  | ||||||
|  "libc", |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "nix" | name = "nix" | ||||||
| version = "0.26.4" | version = "0.26.4" | ||||||
| @ -3074,13 +3016,13 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "num-derive" | name = "num-derive" | ||||||
| version = "0.3.3" | version = "0.4.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "876a53fff98e03a936a674b29568b0e605f06b29372c2489ff4de23f1949743d" | checksum = "ed3955f1a9c7c0c15e092f9c887db08b1fc683305fdf6eb6684f22555355e202" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2", |  "proc-macro2", | ||||||
|  "quote", |  "quote", | ||||||
|  "syn 1.0.109", |  "syn 2.0.66", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -3335,12 +3277,12 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "oboe" | name = "oboe" | ||||||
| version = "0.5.0" | version = "0.6.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "8868cc237ee02e2d9618539a23a8d228b9bb3fc2e7a5b11eed3831de77c395d0" | checksum = "e8b61bebd49e5d43f5f8cc7ee2891c16e0f41ec7954d36bcb6c14c5e0de867fb" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "jni 0.20.0", |  "jni", | ||||||
|  "ndk 0.7.0", |  "ndk 0.8.0", | ||||||
|  "ndk-context", |  "ndk-context", | ||||||
|  "num-derive", |  "num-derive", | ||||||
|  "num-traits", |  "num-traits", | ||||||
| @ -3349,9 +3291,9 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "oboe-sys" | name = "oboe-sys" | ||||||
| version = "0.5.0" | version = "0.6.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "7f44155e7fb718d3cfddcf70690b2b51ac4412f347cd9e4fbe511abe9cd7b5f2" | checksum = "6c8bb09a4a2b1d668170cfe0a7d5bc103f8999fb316c98099b6a9939c9f2e79d" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cc", |  "cc", | ||||||
| ] | ] | ||||||
| @ -3371,6 +3313,12 @@ version = "1.19.0" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" | checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "option-ext" | ||||||
|  | version = "0.2.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "04744f49eae99ab78e0d5c0b603ab218f515ea8cfe5a456d7629ad883a3b6e7d" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "orbclient" | name = "orbclient" | ||||||
| version = "0.3.47" | version = "0.3.47" | ||||||
| @ -3838,15 +3786,16 @@ checksum = "19b30a45b0cd0bcca8037f3d0dc3421eaf95327a17cad11964fb8179b4fc4832" | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "rodio" | name = "rodio" | ||||||
| version = "0.17.1" | version = "0.18.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "bdf1d4dea18dff2e9eb6dca123724f8b60ef44ad74a9ad283cdfe025df7e73fa" | checksum = "d1fceb9d127d515af1586d8d0cc601e1245bdb0af38e75c865a156290184f5b3" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "claxon", |  "claxon", | ||||||
|  "cpal", |  "cpal", | ||||||
|  "hound", |  "hound", | ||||||
|  "lewton", |  "lewton", | ||||||
|  "symphonia", |  "symphonia", | ||||||
|  |  "thiserror", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -4568,14 +4517,14 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "tray-icon" | name = "tray-icon" | ||||||
| version = "0.12.0" | version = "0.14.3" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "454035ff34b8430638c894e6197748578d6b4d449c6edaf8ea854d94e2dd862b" | checksum = "3ad8319cca93189ea9ab1b290de0595960529750b6b8b501a399ed1ec3775d60" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cocoa 0.25.0", |  "cocoa 0.25.0", | ||||||
|  "core-graphics 0.23.1", |  "core-graphics 0.23.1", | ||||||
|  "crossbeam-channel", |  "crossbeam-channel", | ||||||
|  "dirs-next", |  "dirs", | ||||||
|  "libappindicator", |  "libappindicator", | ||||||
|  "muda", |  "muda", | ||||||
|  "objc", |  "objc", | ||||||
| @ -5034,7 +4983,7 @@ checksum = "db67ae75a9405634f5882791678772c94ff5f16a66535aae186e26aa0841fc8b" | |||||||
| dependencies = [ | dependencies = [ | ||||||
|  "core-foundation 0.9.3", |  "core-foundation 0.9.3", | ||||||
|  "home", |  "home", | ||||||
|  "jni 0.21.1", |  "jni", | ||||||
|  "log", |  "log", | ||||||
|  "ndk-context", |  "ndk-context", | ||||||
|  "objc", |  "objc", | ||||||
| @ -5182,15 +5131,6 @@ version = "0.4.0" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" | checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "windows" |  | ||||||
| version = "0.46.0" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "cdacb41e6a96a052c6cb63a144f24900236121c6f63f4f8219fef5977ecb0c25" |  | ||||||
| dependencies = [ |  | ||||||
|  "windows-targets 0.42.2", |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows" | name = "windows" | ||||||
| version = "0.48.0" | version = "0.48.0" | ||||||
| @ -5212,6 +5152,16 @@ dependencies = [ | |||||||
|  "windows-targets 0.48.5", |  "windows-targets 0.48.5", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "windows" | ||||||
|  | version = "0.54.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "9252e5725dbed82865af151df558e754e4a3c2c30818359eb17465f1346a1b49" | ||||||
|  | dependencies = [ | ||||||
|  |  "windows-core 0.54.0", | ||||||
|  |  "windows-targets 0.52.5", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows" | name = "windows" | ||||||
| version = "0.56.0" | version = "0.56.0" | ||||||
| @ -5231,6 +5181,16 @@ dependencies = [ | |||||||
|  "windows-targets 0.48.5", |  "windows-targets 0.48.5", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "windows-core" | ||||||
|  | version = "0.54.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "12661b9c89351d684a50a8a643ce5f608e20243b9fb84687800163429f161d65" | ||||||
|  | dependencies = [ | ||||||
|  |  "windows-result", | ||||||
|  |  "windows-targets 0.52.5", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "windows-core" | name = "windows-core" | ||||||
| version = "0.56.0" | version = "0.56.0" | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ minijinja = { version = "1.0.3", features = ["loader"] } | |||||||
| minimp3 = "0.5.1" | minimp3 = "0.5.1" | ||||||
| mp3-duration = "0.1.10" | mp3-duration = "0.1.10" | ||||||
| regex = "1.9.0" | regex = "1.9.0" | ||||||
| rodio = "0.17.1" | rodio = "0.18.1" | ||||||
| serde = { version = "1.0.171", features = ["derive"] } | serde = { version = "1.0.171", features = ["derive"] } | ||||||
| tokio = { version = "1.29.1", features = ["full"] } | tokio = { version = "1.29.1", features = ["full"] } | ||||||
| xxhash-rust = { version = "0.8.6", features = ["xxh3", "const_xxh3"] } | xxhash-rust = { version = "0.8.6", features = ["xxh3", "const_xxh3"] } | ||||||
| @ -26,7 +26,7 @@ eframe = "0.27.2" | |||||||
| tray-item = "0.10" | tray-item = "0.10" | ||||||
| winit = "0.25" | winit = "0.25" | ||||||
| once_cell = "1.19.0" | once_cell = "1.19.0" | ||||||
| tray-icon = "0.12" | tray-icon = "0.14.3" | ||||||
| raw-window-handle = "0.6.2" | raw-window-handle = "0.6.2" | ||||||
| 
 | 
 | ||||||
| [build-dependencies] | [build-dependencies] | ||||||
|  | |||||||
							
								
								
									
										41
									
								
								src/main.rs
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								src/main.rs
									
									
									
									
									
								
							| @ -1,21 +1,13 @@ | |||||||
| use axum::extract::State; | use axum_template::engine::Engine; | ||||||
| use axum::{routing, routing::get, Router}; |  | ||||||
| use axum_template::{engine::Engine, Key, RenderHtml}; |  | ||||||
| use minijinja::{path_loader, Environment}; | use minijinja::{path_loader, Environment}; | ||||||
| use state::{AppState, TemplateEngine}; | use state::AppState; | ||||||
| 
 | 
 | ||||||
| use log::info; |  | ||||||
| use serde::{Deserialize, Serialize}; |  | ||||||
| use std::env; | use std::env; | ||||||
| use std::{ | use std::sync::{Arc, Mutex}; | ||||||
|     net::SocketAddr, |  | ||||||
|     sync::{Arc, Mutex}, |  | ||||||
|     thread, |  | ||||||
| }; |  | ||||||
| use tokio::sync::mpsc; | use tokio::sync::mpsc; | ||||||
| 
 | 
 | ||||||
| use dotenvy::dotenv; | use dotenvy::dotenv; | ||||||
| use vbplay::{example_handler, AudioThread, DeviceSelection, PlaybackAction, SoundDecoder}; | use vbplay::{example_handler, DeviceSelection, SoundDecoder}; | ||||||
| 
 | 
 | ||||||
| mod handlers; | mod handlers; | ||||||
| mod server; | mod server; | ||||||
| @ -24,9 +16,9 @@ mod state; | |||||||
| mod ui; | mod ui; | ||||||
| mod vbplay; | mod vbplay; | ||||||
| 
 | 
 | ||||||
| #[tokio::main] | fn main() { | ||||||
| async fn main() { |  | ||||||
|     dotenv().ok(); |     dotenv().ok(); | ||||||
|  |     let rt = tokio::runtime::Runtime::new().unwrap(); | ||||||
| 
 | 
 | ||||||
|     let device_pattern = env::var("DEVICE_PATTERN").expect("Need a device pattern"); |     let device_pattern = env::var("DEVICE_PATTERN").expect("Need a device pattern"); | ||||||
|     let folder = env::var("DIRECTORY").expect("Need a directory in env file."); |     let folder = env::var("DIRECTORY").expect("Need a directory in env file."); | ||||||
| @ -60,19 +52,24 @@ async fn main() { | |||||||
| 
 | 
 | ||||||
|     let (ui_to_server_tx, ui_to_server_rx) = mpsc::channel(32); |     let (ui_to_server_tx, ui_to_server_rx) = mpsc::channel(32); | ||||||
| 
 | 
 | ||||||
|     // Run the server in a separate thread
 |     let server_handle = rt.spawn(async move { | ||||||
|     let server_thread = thread::spawn(move || { |         server::run_server(app_state, ui_to_server_rx).await; | ||||||
|         let rt = tokio::runtime::Runtime::new().unwrap(); |  | ||||||
|         rt.block_on(async { |  | ||||||
|             server::run_server(app_state, ui_to_server_rx).await; |  | ||||||
|         }); |  | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     // Run the UI on the main thread
 |     // Run the UI on the main thread
 | ||||||
|     ui::run_ui(server_settings, should_run, ui_to_server_tx); |     ui::run_ui(server_settings, should_run, ui_to_server_tx); | ||||||
| 
 | 
 | ||||||
|     // Wait for the server thread to finish
 |     if let Err(e) = rt.block_on(server_handle) { | ||||||
|     server_thread.join().unwrap(); |         eprintln!("Server task error: {:?}", e); | ||||||
|  |     } else { | ||||||
|  |         println!("Server task completed successfully"); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     rt.shutdown_timeout(tokio::time::Duration::from_secs(5)); | ||||||
|  | 
 | ||||||
|     audio.lock().unwrap().exit(); |     audio.lock().unwrap().exit(); | ||||||
|  |     drop(audio); | ||||||
|  | 
 | ||||||
|     eprintln!("Reached end of program."); |     eprintln!("Reached end of program."); | ||||||
|  |     std::process::exit(0); | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										103
									
								
								src/server.rs
									
									
									
									
									
								
							
							
						
						
									
										103
									
								
								src/server.rs
									
									
									
									
									
								
							| @ -2,12 +2,8 @@ use crate::handlers; | |||||||
| use crate::state::AppState; | use crate::state::AppState; | ||||||
| use axum::{routing, Router}; | use axum::{routing, Router}; | ||||||
| use serde::{Deserialize, Serialize}; | use serde::{Deserialize, Serialize}; | ||||||
| use std::{ | use std::net::SocketAddr; | ||||||
|     net::SocketAddr, |  | ||||||
|     sync::{Arc, Mutex}, |  | ||||||
| }; |  | ||||||
| use tokio::sync::mpsc; | use tokio::sync::mpsc; | ||||||
| use tokio::task::JoinHandle; |  | ||||||
| 
 | 
 | ||||||
| #[derive(Debug, Clone, Serialize, Deserialize)] | #[derive(Debug, Clone, Serialize, Deserialize)] | ||||||
| pub struct ServerSettings { | pub struct ServerSettings { | ||||||
| @ -19,93 +15,82 @@ pub enum ServerMessage { | |||||||
|     UpdateSettings(ServerSettings), |     UpdateSettings(ServerSettings), | ||||||
|     Interact, |     Interact, | ||||||
|     Shutdown, |     Shutdown, | ||||||
|     // Add other message types here
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub async fn run_server(app_state: AppState, mut rx: mpsc::Receiver<ServerMessage>) { | pub async fn run_server(app_state: AppState, mut rx: mpsc::Receiver<ServerMessage>) { | ||||||
|     let mut server_handle = start_server(&app_state); |  | ||||||
| 
 |  | ||||||
|     loop { |     loop { | ||||||
|  |         let should_run = { | ||||||
|  |             let guard = app_state.should_run.lock().unwrap(); | ||||||
|  |             *guard | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         if !should_run { | ||||||
|  |             eprintln!("Should run is false."); | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         let addr = { | ||||||
|  |             let settings = app_state.settings.lock().unwrap(); | ||||||
|  |             let port: u16 = settings.port.parse().unwrap_or(3311); | ||||||
|  |             SocketAddr::from(([0, 0, 0, 0], port)) | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         let server_app_state = app_state.clone(); | ||||||
|  | 
 | ||||||
|  |         println!("listening on {}", addr); | ||||||
|  | 
 | ||||||
|  |         let server_handle = tokio::spawn(async move { | ||||||
|  |             let app = Router::new() | ||||||
|  |                 .route("/", routing::get(handlers::home)) | ||||||
|  |                 .route("/play/:hash", routing::get(handlers::play_handler)) | ||||||
|  |                 .route("/stop", routing::get(handlers::stop_handler)) | ||||||
|  |                 .with_state(server_app_state.clone()); | ||||||
|  | 
 | ||||||
|  |             axum::Server::bind(&addr) | ||||||
|  |                 .serve(app.into_make_service()) | ||||||
|  |                 .await | ||||||
|  |         }); | ||||||
|  |         let server_abort_handle = server_handle.abort_handle(); | ||||||
|  | 
 | ||||||
|         tokio::select! { |         tokio::select! { | ||||||
|             _ = &mut server_handle => { |             _ = server_handle => { | ||||||
|                 // Server has stopped
 |                 // Server has stopped
 | ||||||
|                 eprintln!("Server stopped."); |                 eprintln!("Server stopped."); | ||||||
|  |                 let mut should_run_guard = app_state.should_run.lock().unwrap(); | ||||||
|  |                 *should_run_guard = false; | ||||||
|  |                 drop(should_run_guard); | ||||||
|                 break; |                 break; | ||||||
|             }, |             }, | ||||||
|             Some(message) = rx.recv() => { |             Some(message) = rx.recv() => { | ||||||
|                 match message { |                 match message { | ||||||
|                     // This is the message type that actually restarts the server.
 |  | ||||||
|                     ServerMessage::UpdateSettings(new_settings) => { |                     ServerMessage::UpdateSettings(new_settings) => { | ||||||
|                         println!("Received new settings: {:?}", new_settings); |                         println!("Received new settings: {:?}", new_settings); | ||||||
|                         let mut settings_guard = app_state.settings.lock().unwrap(); |                         let mut settings_guard = app_state.settings.lock().unwrap(); | ||||||
|                         *settings_guard = new_settings; |                         *settings_guard = new_settings; | ||||||
| 
 |                         drop(settings_guard); // Ensure the lock is released before starting the new server
 | ||||||
|                         // Restart the server with new settings
 |                         // Restart the server with new settings
 | ||||||
|                         println!("Aborting current server..."); |                         println!("Aborting current server..."); | ||||||
|                         server_handle.abort(); // Cancel the previous server task
 |                         server_abort_handle.abort(); | ||||||
|                         println!("Starting new server..."); |  | ||||||
|                         drop(settings_guard); // Ensure the lock is released before starting the new server
 |  | ||||||
|                         server_handle = start_server(&app_state); |  | ||||||
|                         println!("Server started."); |  | ||||||
|                     }, |                     }, | ||||||
|                     ServerMessage::Shutdown => { |                     ServerMessage::Shutdown => { | ||||||
|                         // Handle server shutdown
 |                         // Handle server shutdown
 | ||||||
|                         println!("Shutting down server..."); |                         println!("Shutting down server..."); | ||||||
|                         let mut should_run_guard = app_state.should_run.lock().unwrap(); |                         let mut should_run_guard = app_state.should_run.lock().unwrap(); | ||||||
|                         *should_run_guard = false; |                         *should_run_guard = false; | ||||||
|                         server_handle.abort(); |                         drop(should_run_guard); | ||||||
|  |                         server_abort_handle.abort(); | ||||||
|                         println!("Server shutdown."); |                         println!("Server shutdown."); | ||||||
|                         break; |                         break; | ||||||
|                     }, |                     }, | ||||||
|                     // Handle other message types here
 |  | ||||||
|                     ServerMessage::Interact => { |                     ServerMessage::Interact => { | ||||||
|                         // Example interaction: print current settings
 |                         // Example interaction: print current settings
 | ||||||
|                         let settings_guard = app_state.settings.lock().unwrap(); |                         let settings_guard = app_state.settings.lock().unwrap(); | ||||||
|                         println!("Current settings: {:?}", *settings_guard); |                         println!("Current settings: {:?}", *settings_guard); | ||||||
|  |                         server_abort_handle.abort(); | ||||||
|                     }, |                     }, | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } |     eprintln!("Exiting run_server."); | ||||||
| 
 |  | ||||||
| fn start_server(app_state: &AppState) -> JoinHandle<()> { |  | ||||||
|     // Compute the address before entering the async block
 |  | ||||||
|     let addr = { |  | ||||||
|         let settings = app_state.settings.lock().unwrap(); |  | ||||||
|         let port: u16 = settings.port.parse().unwrap_or(3311); |  | ||||||
|         SocketAddr::from(([0, 0, 0, 0], port)) |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     let server_app_state = app_state.clone(); |  | ||||||
| 
 |  | ||||||
|     println!("listening on {}", addr); |  | ||||||
| 
 |  | ||||||
|     tokio::spawn(async move { |  | ||||||
|         let app = Router::new() |  | ||||||
|             .route("/", routing::get(handlers::home)) |  | ||||||
|             .route("/play/:hash", routing::get(handlers::play_handler)) |  | ||||||
|             .route("/stop", routing::get(handlers::stop_handler)) |  | ||||||
|             .with_state(server_app_state.clone()); |  | ||||||
| 
 |  | ||||||
|         let server = axum::Server::bind(&addr).serve(app.into_make_service()); |  | ||||||
| 
 |  | ||||||
|         // Run the server and monitor the should_run flag
 |  | ||||||
|         tokio::select! { |  | ||||||
|             _ = server => { |  | ||||||
|                 eprintln!("Server..."); |  | ||||||
|             }, |  | ||||||
|             _ = monitor_shutdown(server_app_state.should_run.clone()) => { |  | ||||||
|                 println!("Server shutdown signal received"); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| async fn monitor_shutdown(should_run: Arc<Mutex<bool>>) { |  | ||||||
|     eprintln!("Monitoring shutdown..."); |  | ||||||
|     while *should_run.lock().unwrap() { |  | ||||||
|         tokio::time::sleep(tokio::time::Duration::from_secs(1)).await; |  | ||||||
|     } |  | ||||||
|     eprintln!("Shutdown completed."); |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -24,7 +24,7 @@ pub fn run_ui( | |||||||
|             let window_handle = cc.window_handle().unwrap(); |             let window_handle = cc.window_handle().unwrap(); | ||||||
|             let window_handle = window_handle.as_raw(); |             let window_handle = window_handle.as_raw(); | ||||||
|             let mut tray = |             let mut tray = | ||||||
|                 TrayItem::new("App Name", tray_item::IconSource::Resource("icon-red")).unwrap(); |                 TrayItem::new("Soundboard", tray_item::IconSource::Resource("icon-red")).unwrap(); | ||||||
|             if let RawWindowHandle::Win32(handle) = window_handle { |             if let RawWindowHandle::Win32(handle) = window_handle { | ||||||
|                 // Windows Only.
 |                 // Windows Only.
 | ||||||
|                 use windows::Win32::Foundation::HWND; |                 use windows::Win32::Foundation::HWND; | ||||||
| @ -59,8 +59,10 @@ pub fn run_ui( | |||||||
|                 println!("Unsupported platform for tray icon."); |                 println!("Unsupported platform for tray icon."); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             let my_tx = tx.clone(); | ||||||
|             tray.add_menu_item("Quit", move || { |             tray.add_menu_item("Quit", move || { | ||||||
|                 std::process::exit(0); |                 my_tx.try_send(ServerMessage::Shutdown).unwrap(); | ||||||
|  |                 //std::process::exit(0);
 | ||||||
|             }) |             }) | ||||||
|             .unwrap(); |             .unwrap(); | ||||||
| 
 | 
 | ||||||
| @ -119,6 +121,7 @@ impl eframe::App for NativeApp { | |||||||
|                     eprintln!("Failed to send shutdown message"); |                     eprintln!("Failed to send shutdown message"); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |             drop(settings); | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -182,6 +182,10 @@ pub fn audio_thread( | |||||||
|             match command { |             match command { | ||||||
|                 Command::Exit => { |                 Command::Exit => { | ||||||
|                     eprintln!("Exiting Soundloop."); |                     eprintln!("Exiting Soundloop."); | ||||||
|  |                     if let Ok(sink) = sink_mutex.lock() { | ||||||
|  |                         sink.stop(); | ||||||
|  |                     } | ||||||
|  |                     drop(stream_handle); | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 Command::Play(file_name) => { |                 Command::Play(file_name) => { | ||||||
| @ -224,6 +228,7 @@ pub fn audio_thread( | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         eprintln!("Exiting audio_thread"); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     tx |     tx | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user