Skip to content

Commit 037641d

Browse files
committed
ci(rust): update rust ci with mise
1 parent 5563967 commit 037641d

File tree

15 files changed

+475
-172
lines changed

15 files changed

+475
-172
lines changed

LICENSES/CC-BY-4.0.txt

Lines changed: 156 additions & 0 deletions
Large diffs are not rendered by default.

LICENSES/CC0-1.0.txt

Lines changed: 121 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,121 @@
1+
Creative Commons Legal Code
2+
3+
CC0 1.0 Universal
4+
5+
CREATIVE COMMONS CORPORATION IS NOT A LAW FIRM AND DOES NOT PROVIDE
6+
LEGAL SERVICES. DISTRIBUTION OF THIS DOCUMENT DOES NOT CREATE AN
7+
ATTORNEY-CLIENT RELATIONSHIP. CREATIVE COMMONS PROVIDES THIS
8+
INFORMATION ON AN "AS-IS" BASIS. CREATIVE COMMONS MAKES NO WARRANTIES
9+
REGARDING THE USE OF THIS DOCUMENT OR THE INFORMATION OR WORKS
10+
PROVIDED HEREUNDER, AND DISCLAIMS LIABILITY FOR DAMAGES RESULTING FROM
11+
THE USE OF THIS DOCUMENT OR THE INFORMATION OR WORKS PROVIDED
12+
HEREUNDER.
13+
14+
Statement of Purpose
15+
16+
The laws of most jurisdictions throughout the world automatically confer
17+
exclusive Copyright and Related Rights (defined below) upon the creator
18+
and subsequent owner(s) (each and all, an "owner") of an original work of
19+
authorship and/or a database (each, a "Work").
20+
21+
Certain owners wish to permanently relinquish those rights to a Work for
22+
the purpose of contributing to a commons of creative, cultural and
23+
scientific works ("Commons") that the public can reliably and without fear
24+
of later claims of infringement build upon, modify, incorporate in other
25+
works, reuse and redistribute as freely as possible in any form whatsoever
26+
and for any purposes, including without limitation commercial purposes.
27+
These owners may contribute to the Commons to promote the ideal of a free
28+
culture and the further production of creative, cultural and scientific
29+
works, or to gain reputation or greater distribution for their Work in
30+
part through the use and efforts of others.
31+
32+
For these and/or other purposes and motivations, and without any
33+
expectation of additional consideration or compensation, the person
34+
associating CC0 with a Work (the "Affirmer"), to the extent that he or she
35+
is an owner of Copyright and Related Rights in the Work, voluntarily
36+
elects to apply CC0 to the Work and publicly distribute the Work under its
37+
terms, with knowledge of his or her Copyright and Related Rights in the
38+
Work and the meaning and intended legal effect of CC0 on those rights.
39+
40+
1. Copyright and Related Rights. A Work made available under CC0 may be
41+
protected by copyright and related or neighboring rights ("Copyright and
42+
Related Rights"). Copyright and Related Rights include, but are not
43+
limited to, the following:
44+
45+
i. the right to reproduce, adapt, distribute, perform, display,
46+
communicate, and translate a Work;
47+
ii. moral rights retained by the original author(s) and/or performer(s);
48+
iii. publicity and privacy rights pertaining to a person's image or
49+
likeness depicted in a Work;
50+
iv. rights protecting against unfair competition in regards to a Work,
51+
subject to the limitations in paragraph 4(a), below;
52+
v. rights protecting the extraction, dissemination, use and reuse of data
53+
in a Work;
54+
vi. database rights (such as those arising under Directive 96/9/EC of the
55+
European Parliament and of the Council of 11 March 1996 on the legal
56+
protection of databases, and under any national implementation
57+
thereof, including any amended or successor version of such
58+
directive); and
59+
vii. other similar, equivalent or corresponding rights throughout the
60+
world based on applicable law or treaty, and any national
61+
implementations thereof.
62+
63+
2. Waiver. To the greatest extent permitted by, but not in contravention
64+
of, applicable law, Affirmer hereby overtly, fully, permanently,
65+
irrevocably and unconditionally waives, abandons, and surrenders all of
66+
Affirmer's Copyright and Related Rights and associated claims and causes
67+
of action, whether now known or unknown (including existing as well as
68+
future claims and causes of action), in the Work (i) in all territories
69+
worldwide, (ii) for the maximum duration provided by applicable law or
70+
treaty (including future time extensions), (iii) in any current or future
71+
medium and for any number of copies, and (iv) for any purpose whatsoever,
72+
including without limitation commercial, advertising or promotional
73+
purposes (the "Waiver"). Affirmer makes the Waiver for the benefit of each
74+
member of the public at large and to the detriment of Affirmer's heirs and
75+
successors, fully intending that such Waiver shall not be subject to
76+
revocation, rescission, cancellation, termination, or any other legal or
77+
equitable action to disrupt the quiet enjoyment of the Work by the public
78+
as contemplated by Affirmer's express Statement of Purpose.
79+
80+
3. Public License Fallback. Should any part of the Waiver for any reason
81+
be judged legally invalid or ineffective under applicable law, then the
82+
Waiver shall be preserved to the maximum extent permitted taking into
83+
account Affirmer's express Statement of Purpose. In addition, to the
84+
extent the Waiver is so judged Affirmer hereby grants to each affected
85+
person a royalty-free, non transferable, non sublicensable, non exclusive,
86+
irrevocable and unconditional license to exercise Affirmer's Copyright and
87+
Related Rights in the Work (i) in all territories worldwide, (ii) for the
88+
maximum duration provided by applicable law or treaty (including future
89+
time extensions), (iii) in any current or future medium and for any number
90+
of copies, and (iv) for any purpose whatsoever, including without
91+
limitation commercial, advertising or promotional purposes (the
92+
"License"). The License shall be deemed effective as of the date CC0 was
93+
applied by Affirmer to the Work. Should any part of the License for any
94+
reason be judged legally invalid or ineffective under applicable law, such
95+
partial invalidity or ineffectiveness shall not invalidate the remainder
96+
of the License, and in such case Affirmer hereby affirms that he or she
97+
will not (i) exercise any of his or her remaining Copyright and Related
98+
Rights in the Work or (ii) assert any associated claims and causes of
99+
action with respect to the Work, in either case contrary to Affirmer's
100+
express Statement of Purpose.
101+
102+
4. Limitations and Disclaimers.
103+
104+
a. No trademark or patent rights held by Affirmer are waived, abandoned,
105+
surrendered, licensed or otherwise affected by this document.
106+
b. Affirmer offers the Work as-is and makes no representations or
107+
warranties of any kind concerning the Work, express, implied,
108+
statutory or otherwise, including without limitation warranties of
109+
title, merchantability, fitness for a particular purpose, non
110+
infringement, or the absence of latent or other defects, accuracy, or
111+
the present or absence of errors, whether or not discoverable, all to
112+
the greatest extent permissible under applicable law.
113+
c. Affirmer disclaims responsibility for clearing rights of other persons
114+
that may apply to the Work or any use thereof, including without
115+
limitation any person's Copyright and Related Rights in the Work.
116+
Further, Affirmer disclaims responsibility for obtaining any necessary
117+
consents, permissions or other rights required for any use of the
118+
Work.
119+
d. Affirmer understands and acknowledges that Creative Commons is not a
120+
party to this document and has no duty or obligation with respect to
121+
this CC0 or use of the Work.

REUSE.toml

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,15 @@ SPDX-License-Identifier = "AGPL-3.0-only OR LicenseRef-Commercial"
77

88
# Configuration files (Public Domain)
99
[[annotations]]
10-
path = ["*.json", "*.yaml", "*.toml", ".gitignore", ".env.example"]
10+
path = [
11+
".cargo/**",
12+
".github/**",
13+
"*.json",
14+
"*.yaml",
15+
"*.toml",
16+
".gitignore",
17+
".env.example",
18+
]
1119
SPDX-FileCopyrightText = "2026 AprilNEA LLC"
1220
SPDX-License-Identifier = "CC0-1.0"
1321

@@ -25,6 +33,6 @@ SPDX-License-Identifier = "CC-BY-4.0"
2533

2634
# Static resources
2735
[[annotations]]
28-
path = ["public/**", "assets/**", "locales/**"]
36+
path = ["public/**", "assets/**", "locales/**", "bundle/**"]
2937
SPDX-FileCopyrightText = "2026 AprilNEA LLC"
3038
SPDX-License-Identifier = "CC-BY-4.0"

src/app.rs

Lines changed: 6 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -5,10 +5,12 @@
55
use std::time::Duration;
66

77
use gpui::*;
8-
use gpui_component::{h_flex, v_flex, ActiveTheme};
8+
use gpui_component::{ActiveTheme, h_flex, v_flex};
99
use gpui_tokio_bridge::Tokio;
1010

11-
use crate::chat_sidebar::{ChatSidebar, ConversationSelectedEvent, NewChatEvent, SidebarToggleEvent};
11+
use crate::chat_sidebar::{
12+
ChatSidebar, ConversationSelectedEvent, NewChatEvent, SidebarToggleEvent,
13+
};
1214
use crate::chat_view::{ChatView, ConversationUpdatedEvent};
1315
use crate::database;
1416
use crate::model_selector::{ModelSelector, ModelSelectorChangedEvent};
@@ -135,7 +137,8 @@ impl Render for ChatApp {
135137
.child(self.sidebar.clone())
136138
.with_animation(
137139
ElementId::Name(
138-
format!("sidebar-{}", if collapsed { "collapse" } else { "expand" }).into(),
140+
format!("sidebar-{}", if collapsed { "collapse" } else { "expand" })
141+
.into(),
139142
),
140143
Animation::new(SIDEBAR_ANIMATION_DURATION),
141144
move |el, delta| {

src/chat_sidebar.rs

Lines changed: 8 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -5,13 +5,14 @@
55
use chrono::{Datelike, Local};
66
use gpui::*;
77
use gpui_component::{
8+
ActiveTheme, Icon, IconName, Sizable,
89
button::{Button, ButtonVariants},
910
h_flex,
1011
input::{Input, InputState},
1112
label::Label,
1213
list::ListItem,
1314
scroll::ScrollableElement,
14-
v_flex, ActiveTheme, Icon, IconName, Sizable,
15+
v_flex,
1516
};
1617
use gpui_tokio_bridge::Tokio;
1718
use uuid::Uuid;
@@ -167,16 +168,12 @@ impl ChatSidebar {
167168
}
168169

169170
fn render_search(&mut self, _cx: &mut Context<Self>) -> impl IntoElement {
170-
h_flex()
171-
.w_full()
172-
.px_3()
173-
.pb_2()
174-
.child(
175-
Input::new(&self.search_input)
176-
.prefix(Icon::new(IconName::Search).size_4())
177-
.xsmall()
178-
.appearance(false),
179-
)
171+
h_flex().w_full().px_3().pb_2().child(
172+
Input::new(&self.search_input)
173+
.prefix(Icon::new(IconName::Search).size_4())
174+
.xsmall()
175+
.appearance(false),
176+
)
180177
}
181178

182179
fn render_quick_tags(&mut self, cx: &mut Context<Self>) -> impl IntoElement {

src/chat_view.rs

Lines changed: 18 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@
33
// SPDX-License-Identifier: AGPL-3.0-only OR LicenseRef-Commercial
44

55
use gpui::*;
6-
use gpui_component::{v_flex, ActiveTheme};
6+
use gpui_component::{ActiveTheme, v_flex};
77
use gpui_tokio_bridge::Tokio;
88
use uuid::Uuid;
99

@@ -46,10 +46,13 @@ impl ChatView {
4646
tracing::warn!("No LLM provider configured. Please set up in Settings.");
4747
}
4848

49-
let _subscription =
50-
cx.subscribe_in(&message_input, window, |this, _, event: &SubmitEvent, window, cx| {
49+
let _subscription = cx.subscribe_in(
50+
&message_input,
51+
window,
52+
|this, _, event: &SubmitEvent, window, cx| {
5153
this.handle_user_message(event.0.clone(), window, cx);
52-
});
54+
},
55+
);
5356

5457
let mut messages = Vec::new();
5558
messages.push(Message::system("You are a helpful assistant."));
@@ -68,7 +71,8 @@ impl ChatView {
6871
/// Start a new chat (clear messages and conversation)
6972
pub fn new_chat(&mut self, cx: &mut Context<Self>) {
7073
self.messages.clear();
71-
self.messages.push(Message::system("You are a helpful assistant."));
74+
self.messages
75+
.push(Message::system("You are a helpful assistant."));
7276
self.current_conversation_id = None;
7377
self.update_message_list(cx);
7478
}
@@ -77,7 +81,8 @@ impl ChatView {
7781
pub fn load_conversation(&mut self, conversation_id: Uuid, cx: &mut Context<Self>) {
7882
self.current_conversation_id = Some(conversation_id);
7983
self.messages.clear();
80-
self.messages.push(Message::system("You are a helpful assistant."));
84+
self.messages
85+
.push(Message::system("You are a helpful assistant."));
8186

8287
let db = database::get_db(cx).clone();
8388
let (tx, rx) = async_channel::unbounded();
@@ -206,7 +211,13 @@ impl ChatView {
206211
.detach();
207212
}
208213

209-
fn save_message_to_db(&self, _message_id: Uuid, role: Role, content: String, cx: &mut Context<Self>) {
214+
fn save_message_to_db(
215+
&self,
216+
_message_id: Uuid,
217+
role: Role,
218+
content: String,
219+
cx: &mut Context<Self>,
220+
) {
210221
let Some(conversation_id) = self.current_conversation_id else {
211222
return;
212223
};

src/database/mod.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,4 +9,4 @@ pub mod repository;
99
pub mod service;
1010

1111
pub use entity::{conversation, message};
12-
pub use service::{get_db, init, DatabaseService};
12+
pub use service::{DatabaseService, get_db, init};

src/database/service.rs

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -126,7 +126,11 @@ impl DatabaseService {
126126
}
127127

128128
/// Update message content
129-
pub async fn update_message_content(&self, id: Uuid, content: String) -> Result<message::Model> {
129+
pub async fn update_message_content(
130+
&self,
131+
id: Uuid,
132+
content: String,
133+
) -> Result<message::Model> {
130134
let conn = self.get_connection().await?;
131135
MessageRepository::update_content(&conn, id, content).await
132136
}

src/llm_client.rs

Lines changed: 12 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
//
33
// SPDX-License-Identifier: AGPL-3.0-only OR LicenseRef-Commercial
44

5-
use anyhow::{anyhow, Result};
5+
use anyhow::{Result, anyhow};
66
use futures::StreamExt;
77
use reqwest::Client;
88
use serde::{Deserialize, Serialize};
@@ -145,9 +145,12 @@ impl LlmClient {
145145

146146
if !response.status().is_success() {
147147
let error_text = response.text().await.unwrap_or_default();
148-
tx.send(StreamEventResult::Error(format!("API error: {}", error_text)))
149-
.await
150-
.ok();
148+
tx.send(StreamEventResult::Error(format!(
149+
"API error: {}",
150+
error_text
151+
)))
152+
.await
153+
.ok();
151154
return Err(anyhow!("API error: {}", error_text));
152155
}
153156

@@ -182,9 +185,11 @@ impl LlmClient {
182185
return Ok(());
183186
}
184187
"error" => {
185-
tx.send(StreamEventResult::Error(t!("error.stream_error").to_string()))
186-
.await
187-
.ok();
188+
tx.send(StreamEventResult::Error(
189+
t!("error.stream_error").to_string(),
190+
))
191+
.await
192+
.ok();
188193
return Ok(());
189194
}
190195
_ => {}

src/main.rs

Lines changed: 11 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@ use gpui::*;
2424
use gpui_component::Root;
2525
use gpui_component_assets::Assets;
2626

27-
use settings::{open_settings_window, OpenSettings};
27+
use settings::{OpenSettings, open_settings_window};
2828

2929
actions!(app, [Quit]);
3030

@@ -111,18 +111,16 @@ fn main() {
111111
]);
112112

113113
// Set up menu bar
114-
cx.set_menus(vec![
115-
Menu {
116-
name: t!("app.name").to_string().into(),
117-
items: vec![
118-
MenuItem::action(t!("app.about").to_string(), Quit),
119-
MenuItem::separator(),
120-
MenuItem::action(t!("app.settings").to_string(), OpenSettings),
121-
MenuItem::separator(),
122-
MenuItem::action(t!("app.quit").to_string(), Quit),
123-
],
124-
},
125-
]);
114+
cx.set_menus(vec![Menu {
115+
name: t!("app.name").to_string().into(),
116+
items: vec![
117+
MenuItem::action(t!("app.about").to_string(), Quit),
118+
MenuItem::separator(),
119+
MenuItem::action(t!("app.settings").to_string(), OpenSettings),
120+
MenuItem::separator(),
121+
MenuItem::action(t!("app.quit").to_string(), Quit),
122+
],
123+
}]);
126124

127125
cx.spawn(async move |cx| {
128126
cx.update(|cx| {

0 commit comments

Comments
 (0)