24 changed files with 878 additions and 4365 deletions
@ -1 +1,8 @@ |
|||||||
/text_editor/target |
/text_editor/target |
||||||
|
/win_text_editor/android/app |
||||||
|
/win_text_editor/ios |
||||||
|
/win_text_editor/linux |
||||||
|
/win_text_editor/android |
||||||
|
/win_text_editor/macos |
||||||
|
/win_text_editor/web |
||||||
|
/win_text_editor/windows/runner |
||||||
|
@ -1,13 +0,0 @@ |
|||||||
{ |
|
||||||
"version": "0.2.0", |
|
||||||
"configurations": [ |
|
||||||
{ |
|
||||||
"type": "lldb", |
|
||||||
"request": "launch", |
|
||||||
"name": "Debug", |
|
||||||
"program": "${workspaceFolder}/target/debug/text_editor", |
|
||||||
"args": [], |
|
||||||
"cwd": "${workspaceFolder}" |
|
||||||
} |
|
||||||
] |
|
||||||
} |
|
File diff suppressed because it is too large
Load Diff
@ -1,26 +0,0 @@ |
|||||||
[package] |
|
||||||
name = "text_editor" |
|
||||||
version = "0.1.0" |
|
||||||
edition = "2024" |
|
||||||
|
|
||||||
[dependencies] |
|
||||||
# GUI框架 |
|
||||||
egui = "0.31.1" # 用于界面 |
|
||||||
eframe = "0.31.1" # 用于应用框架 |
|
||||||
# 文件系统操作 |
|
||||||
walkdir = "2.4" |
|
||||||
# 文本处理 |
|
||||||
regex = "1.10" |
|
||||||
# Windows特定功能 |
|
||||||
windows = { version = "0.61.1", features = [ |
|
||||||
"Win32_Foundation", |
|
||||||
"Win32_UI_WindowsAndMessaging", |
|
||||||
"Win32_UI_Shell", |
|
||||||
"Win32_Storage_FileSystem", |
|
||||||
] } |
|
||||||
|
|
||||||
serde = { version = "1.0", features = ["derive"] } |
|
||||||
serde_json = "1.0" |
|
||||||
|
|
||||||
[package.metadata.bundle] |
|
||||||
windows = ["msyh.ttf"] # 确保字体打包进安装程序 |
|
Binary file not shown.
@ -1,116 +0,0 @@ |
|||||||
use eframe::egui; |
|
||||||
use egui::{ScrollArea, TextEdit}; |
|
||||||
use serde_json::{Value, to_string_pretty}; |
|
||||||
use std::path::{Path, PathBuf}; |
|
||||||
use walkdir::WalkDir; |
|
||||||
|
|
||||||
pub struct TextEditorApp { |
|
||||||
current_dir: String, |
|
||||||
files: Vec<PathBuf>, |
|
||||||
selected_file: Option<PathBuf>, |
|
||||||
file_content: String, |
|
||||||
pending_selection: Option<PathBuf>, // 新增字段用于延迟加载
|
|
||||||
} |
|
||||||
|
|
||||||
impl Default for TextEditorApp { |
|
||||||
fn default() -> Self { |
|
||||||
Self { |
|
||||||
current_dir: String::from("C:\\"), |
|
||||||
files: Vec::new(), |
|
||||||
selected_file: None, |
|
||||||
file_content: String::new(), |
|
||||||
pending_selection: None, |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
impl eframe::App for TextEditorApp { |
|
||||||
fn update(&mut self, ctx: &egui::Context, _frame: &mut eframe::Frame) { |
|
||||||
// 先处理待处理的文件选择
|
|
||||||
if let Some(file_path) = self.pending_selection.take() { |
|
||||||
self.selected_file = Some(file_path.clone()); |
|
||||||
self.load_file_content(&file_path); |
|
||||||
} |
|
||||||
|
|
||||||
let available_height = ctx.available_rect().height() - 40.0; |
|
||||||
|
|
||||||
egui::SidePanel::left("resource_panel") |
|
||||||
.resizable(false) |
|
||||||
.default_width(200.0) |
|
||||||
.show(ctx, |ui| { |
|
||||||
ui.set_height(available_height); |
|
||||||
ScrollArea::vertical().show(ui, |ui| { |
|
||||||
ui.label("项目文件"); |
|
||||||
ui.separator(); |
|
||||||
|
|
||||||
// 保存文件列表到临时变量避免借用冲突
|
|
||||||
let files = self.files.clone(); |
|
||||||
for file in files { |
|
||||||
if ui.selectable_label( |
|
||||||
self.selected_file.as_ref() == Some(&file), |
|
||||||
file.file_name().unwrap().to_string_lossy() |
|
||||||
).clicked() { |
|
||||||
// 不直接调用load方法,而是设置待处理选择
|
|
||||||
self.pending_selection = Some(file); |
|
||||||
} |
|
||||||
} |
|
||||||
}); |
|
||||||
}); |
|
||||||
|
|
||||||
egui::CentralPanel::default() |
|
||||||
.frame(egui::Frame::NONE) |
|
||||||
.show(ctx, |ui| { |
|
||||||
TextEdit::multiline(&mut self.file_content) |
|
||||||
.desired_width(f32::INFINITY) |
|
||||||
.desired_rows((available_height / 20.0) as usize) |
|
||||||
.font(egui::TextStyle::Monospace) |
|
||||||
.show(ui); |
|
||||||
}); |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
impl TextEditorApp { |
|
||||||
fn load_directory(&mut self) { |
|
||||||
self.files.clear(); |
|
||||||
self.selected_file = None; |
|
||||||
self.file_content.clear(); |
|
||||||
|
|
||||||
let path = Path::new(&self.current_dir); |
|
||||||
if path.is_dir() { |
|
||||||
for entry in WalkDir::new(path) |
|
||||||
.max_depth(1) |
|
||||||
.into_iter() |
|
||||||
.filter_map(|e| e.ok()) |
|
||||||
{ |
|
||||||
if entry.file_type().is_file() { |
|
||||||
self.files.push(entry.path().to_path_buf()); |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
fn load_file_content(&mut self, file_path: &Path) { |
|
||||||
self.file_content = std::fs::read_to_string(file_path).unwrap_or_default(); |
|
||||||
} |
|
||||||
|
|
||||||
fn convert_to_uppercase(&mut self) { |
|
||||||
self.file_content = self.file_content.to_uppercase(); |
|
||||||
} |
|
||||||
|
|
||||||
fn convert_to_lowercase(&mut self) { |
|
||||||
self.file_content = self.file_content.to_lowercase(); |
|
||||||
} |
|
||||||
|
|
||||||
fn format_json(&mut self) { |
|
||||||
match serde_json::from_str::<Value>(&self.file_content) { |
|
||||||
Ok(parsed) => { |
|
||||||
if let Ok(formatted) = to_string_pretty(&parsed) { |
|
||||||
self.file_content = formatted; |
|
||||||
} |
|
||||||
} |
|
||||||
Err(e) => { |
|
||||||
println!("JSON 格式化错误: {}", e); |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
@ -1,25 +0,0 @@ |
|||||||
use std::path::{Path, PathBuf}; |
|
||||||
use walkdir::WalkDir; |
|
||||||
|
|
||||||
pub fn list_files_in_dir(path: &str) -> Vec<PathBuf> { |
|
||||||
let mut files = Vec::new(); |
|
||||||
let path = Path::new(path); |
|
||||||
|
|
||||||
if path.is_dir() { |
|
||||||
for entry in WalkDir::new(path) |
|
||||||
.max_depth(1) |
|
||||||
.into_iter() |
|
||||||
.filter_map(|e| e.ok()) |
|
||||||
{ |
|
||||||
if entry.file_type().is_file() { |
|
||||||
files.push(entry.path().to_path_buf()); |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
files |
|
||||||
} |
|
||||||
|
|
||||||
pub fn read_file_content(file_path: &Path) -> Option<String> { |
|
||||||
std::fs::read_to_string(file_path).ok() |
|
||||||
} |
|
@ -1,51 +0,0 @@ |
|||||||
mod app; |
|
||||||
|
|
||||||
use app::TextEditorApp; |
|
||||||
use eframe::egui; |
|
||||||
|
|
||||||
fn main() -> eframe::Result<()> { |
|
||||||
let options = eframe::NativeOptions { |
|
||||||
viewport: egui::ViewportBuilder::default().with_inner_size([1000.0, 600.0]), |
|
||||||
..Default::default() |
|
||||||
}; |
|
||||||
|
|
||||||
eframe::run_native( |
|
||||||
"文本编辑器", |
|
||||||
options, |
|
||||||
Box::new(|cc| { |
|
||||||
// 1. 创建字体配置
|
|
||||||
let mut fonts = egui::FontDefinitions::default(); |
|
||||||
|
|
||||||
// 2. 加载字体数据(确保文件存在)
|
|
||||||
if let Ok(font_data) = std::fs::read("msyh.ttf") { |
|
||||||
fonts.font_data.insert( |
|
||||||
"msyh".to_owned(), |
|
||||||
egui::FontData::from_owned(font_data).into(), // 使用Arc包装
|
|
||||||
); |
|
||||||
|
|
||||||
// 3. 设置字体优先级
|
|
||||||
fonts.families.insert( |
|
||||||
egui::FontFamily::Proportional, |
|
||||||
vec!["msyh".to_owned()], // 主字体
|
|
||||||
); |
|
||||||
|
|
||||||
// 保留默认字体作为后备
|
|
||||||
fonts |
|
||||||
.families |
|
||||||
.get_mut(&egui::FontFamily::Proportional) |
|
||||||
.unwrap() |
|
||||||
.extend( |
|
||||||
egui::FontDefinitions::default().families[&egui::FontFamily::Proportional] |
|
||||||
.clone(), |
|
||||||
); |
|
||||||
} else { |
|
||||||
eprintln!("警告: 未找到msyh.ttf字体文件,使用默认字体"); |
|
||||||
} |
|
||||||
|
|
||||||
// 4. 应用字体配置
|
|
||||||
cc.egui_ctx.set_fonts(fonts); |
|
||||||
|
|
||||||
Ok(Box::new(TextEditorApp::default())) |
|
||||||
}), |
|
||||||
) |
|
||||||
} |
|
@ -1,22 +0,0 @@ |
|||||||
use regex::Regex; |
|
||||||
use serde_json::{Value, to_string_pretty}; |
|
||||||
|
|
||||||
pub fn to_uppercase(text: &str) -> String { |
|
||||||
text.to_uppercase() |
|
||||||
} |
|
||||||
|
|
||||||
pub fn to_lowercase(text: &str) -> String { |
|
||||||
text.to_lowercase() |
|
||||||
} |
|
||||||
|
|
||||||
pub fn format_json(text: &str) -> Option<String> { |
|
||||||
match serde_json::from_str::<Value>(text) { |
|
||||||
Ok(parsed) => to_string_pretty(&parsed).ok(), |
|
||||||
Err(_) => None, |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
pub fn extract_emails(text: &str) -> Vec<String> { |
|
||||||
let re = Regex::new(r"\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b").unwrap(); |
|
||||||
re.find_iter(text).map(|m| m.as_str().to_string()).collect() |
|
||||||
} |
|
@ -0,0 +1,45 @@ |
|||||||
|
# Miscellaneous |
||||||
|
*.class |
||||||
|
*.log |
||||||
|
*.pyc |
||||||
|
*.swp |
||||||
|
.DS_Store |
||||||
|
.atom/ |
||||||
|
.build/ |
||||||
|
.buildlog/ |
||||||
|
.history |
||||||
|
.svn/ |
||||||
|
.swiftpm/ |
||||||
|
migrate_working_dir/ |
||||||
|
|
||||||
|
# IntelliJ related |
||||||
|
*.iml |
||||||
|
*.ipr |
||||||
|
*.iws |
||||||
|
.idea/ |
||||||
|
|
||||||
|
# The .vscode folder contains launch configuration and tasks you configure in |
||||||
|
# VS Code which you may wish to be included in version control, so this line |
||||||
|
# is commented out by default. |
||||||
|
#.vscode/ |
||||||
|
|
||||||
|
# Flutter/Dart/Pub related |
||||||
|
**/doc/api/ |
||||||
|
**/ios/Flutter/.last_build_id |
||||||
|
.dart_tool/ |
||||||
|
.flutter-plugins |
||||||
|
.flutter-plugins-dependencies |
||||||
|
.pub-cache/ |
||||||
|
.pub/ |
||||||
|
/build/ |
||||||
|
|
||||||
|
# Symbolication related |
||||||
|
app.*.symbols |
||||||
|
|
||||||
|
# Obfuscation related |
||||||
|
app.*.map.json |
||||||
|
|
||||||
|
# Android Studio will place build artifacts here |
||||||
|
/android/app/debug |
||||||
|
/android/app/profile |
||||||
|
/android/app/release |
@ -0,0 +1,45 @@ |
|||||||
|
# This file tracks properties of this Flutter project. |
||||||
|
# Used by Flutter tool to assess capabilities and perform upgrades etc. |
||||||
|
# |
||||||
|
# This file should be version controlled and should not be manually edited. |
||||||
|
|
||||||
|
version: |
||||||
|
revision: "09de023485e95e6d1225c2baa44b8feb85e0d45f" |
||||||
|
channel: "stable" |
||||||
|
|
||||||
|
project_type: app |
||||||
|
|
||||||
|
# Tracks metadata for the flutter migrate command |
||||||
|
migration: |
||||||
|
platforms: |
||||||
|
- platform: root |
||||||
|
create_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
base_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
- platform: android |
||||||
|
create_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
base_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
- platform: ios |
||||||
|
create_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
base_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
- platform: linux |
||||||
|
create_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
base_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
- platform: macos |
||||||
|
create_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
base_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
- platform: web |
||||||
|
create_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
base_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
- platform: windows |
||||||
|
create_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
base_revision: 09de023485e95e6d1225c2baa44b8feb85e0d45f |
||||||
|
|
||||||
|
# User provided section |
||||||
|
|
||||||
|
# List of Local paths (relative to this file) that should be |
||||||
|
# ignored by the migrate tool. |
||||||
|
# |
||||||
|
# Files that are not part of the templates will be ignored by default. |
||||||
|
unmanaged_files: |
||||||
|
- 'lib/main.dart' |
||||||
|
- 'ios/Runner.xcodeproj/project.pbxproj' |
@ -0,0 +1,16 @@ |
|||||||
|
# win_text_editor |
||||||
|
|
||||||
|
A new Flutter project. |
||||||
|
|
||||||
|
## Getting Started |
||||||
|
|
||||||
|
This project is a starting point for a Flutter application. |
||||||
|
|
||||||
|
A few resources to get you started if this is your first Flutter project: |
||||||
|
|
||||||
|
- [Lab: Write your first Flutter app](https://docs.flutter.dev/get-started/codelab) |
||||||
|
- [Cookbook: Useful Flutter samples](https://docs.flutter.dev/cookbook) |
||||||
|
|
||||||
|
For help getting started with Flutter development, view the |
||||||
|
[online documentation](https://docs.flutter.dev/), which offers tutorials, |
||||||
|
samples, guidance on mobile development, and a full API reference. |
@ -0,0 +1,28 @@ |
|||||||
|
# This file configures the analyzer, which statically analyzes Dart code to |
||||||
|
# check for errors, warnings, and lints. |
||||||
|
# |
||||||
|
# The issues identified by the analyzer are surfaced in the UI of Dart-enabled |
||||||
|
# IDEs (https://dart.dev/tools#ides-and-editors). The analyzer can also be |
||||||
|
# invoked from the command line by running `flutter analyze`. |
||||||
|
|
||||||
|
# The following line activates a set of recommended lints for Flutter apps, |
||||||
|
# packages, and plugins designed to encourage good coding practices. |
||||||
|
include: package:flutter_lints/flutter.yaml |
||||||
|
|
||||||
|
linter: |
||||||
|
# The lint rules applied to this project can be customized in the |
||||||
|
# section below to disable rules from the `package:flutter_lints/flutter.yaml` |
||||||
|
# included above or to enable additional rules. A list of all available lints |
||||||
|
# and their documentation is published at https://dart.dev/lints. |
||||||
|
# |
||||||
|
# Instead of disabling a lint rule for the entire project in the |
||||||
|
# section below, it can also be suppressed for a single line of code |
||||||
|
# or a specific dart file by using the `// ignore: name_of_lint` and |
||||||
|
# `// ignore_for_file: name_of_lint` syntax on the line or in the file |
||||||
|
# producing the lint. |
||||||
|
rules: |
||||||
|
# avoid_print: false # Uncomment to disable the `avoid_print` rule |
||||||
|
# prefer_single_quotes: true # Uncomment to enable the `prefer_single_quotes` rule |
||||||
|
|
||||||
|
# Additional information about this file can be found at |
||||||
|
# https://dart.dev/guides/language/analysis-options |
@ -0,0 +1,122 @@ |
|||||||
|
import 'package:flutter/material.dart'; |
||||||
|
|
||||||
|
void main() { |
||||||
|
runApp(const MyApp()); |
||||||
|
} |
||||||
|
|
||||||
|
class MyApp extends StatelessWidget { |
||||||
|
const MyApp({super.key}); |
||||||
|
|
||||||
|
// This widget is the root of your application. |
||||||
|
@override |
||||||
|
Widget build(BuildContext context) { |
||||||
|
return MaterialApp( |
||||||
|
title: 'Flutter Demo', |
||||||
|
theme: ThemeData( |
||||||
|
// This is the theme of your application. |
||||||
|
// |
||||||
|
// TRY THIS: Try running your application with "flutter run". You'll see |
||||||
|
// the application has a purple toolbar. Then, without quitting the app, |
||||||
|
// try changing the seedColor in the colorScheme below to Colors.green |
||||||
|
// and then invoke "hot reload" (save your changes or press the "hot |
||||||
|
// reload" button in a Flutter-supported IDE, or press "r" if you used |
||||||
|
// the command line to start the app). |
||||||
|
// |
||||||
|
// Notice that the counter didn't reset back to zero; the application |
||||||
|
// state is not lost during the reload. To reset the state, use hot |
||||||
|
// restart instead. |
||||||
|
// |
||||||
|
// This works for code too, not just values: Most code changes can be |
||||||
|
// tested with just a hot reload. |
||||||
|
colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple), |
||||||
|
), |
||||||
|
home: const MyHomePage(title: 'Flutter Demo Home Page'), |
||||||
|
); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
class MyHomePage extends StatefulWidget { |
||||||
|
const MyHomePage({super.key, required this.title}); |
||||||
|
|
||||||
|
// This widget is the home page of your application. It is stateful, meaning |
||||||
|
// that it has a State object (defined below) that contains fields that affect |
||||||
|
// how it looks. |
||||||
|
|
||||||
|
// This class is the configuration for the state. It holds the values (in this |
||||||
|
// case the title) provided by the parent (in this case the App widget) and |
||||||
|
// used by the build method of the State. Fields in a Widget subclass are |
||||||
|
// always marked "final". |
||||||
|
|
||||||
|
final String title; |
||||||
|
|
||||||
|
@override |
||||||
|
State<MyHomePage> createState() => _MyHomePageState(); |
||||||
|
} |
||||||
|
|
||||||
|
class _MyHomePageState extends State<MyHomePage> { |
||||||
|
int _counter = 0; |
||||||
|
|
||||||
|
void _incrementCounter() { |
||||||
|
setState(() { |
||||||
|
// This call to setState tells the Flutter framework that something has |
||||||
|
// changed in this State, which causes it to rerun the build method below |
||||||
|
// so that the display can reflect the updated values. If we changed |
||||||
|
// _counter without calling setState(), then the build method would not be |
||||||
|
// called again, and so nothing would appear to happen. |
||||||
|
_counter++; |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
@override |
||||||
|
Widget build(BuildContext context) { |
||||||
|
// This method is rerun every time setState is called, for instance as done |
||||||
|
// by the _incrementCounter method above. |
||||||
|
// |
||||||
|
// The Flutter framework has been optimized to make rerunning build methods |
||||||
|
// fast, so that you can just rebuild anything that needs updating rather |
||||||
|
// than having to individually change instances of widgets. |
||||||
|
return Scaffold( |
||||||
|
appBar: AppBar( |
||||||
|
// TRY THIS: Try changing the color here to a specific color (to |
||||||
|
// Colors.amber, perhaps?) and trigger a hot reload to see the AppBar |
||||||
|
// change color while the other colors stay the same. |
||||||
|
backgroundColor: Theme.of(context).colorScheme.inversePrimary, |
||||||
|
// Here we take the value from the MyHomePage object that was created by |
||||||
|
// the App.build method, and use it to set our appbar title. |
||||||
|
title: Text(widget.title), |
||||||
|
), |
||||||
|
body: Center( |
||||||
|
// Center is a layout widget. It takes a single child and positions it |
||||||
|
// in the middle of the parent. |
||||||
|
child: Column( |
||||||
|
// Column is also a layout widget. It takes a list of children and |
||||||
|
// arranges them vertically. By default, it sizes itself to fit its |
||||||
|
// children horizontally, and tries to be as tall as its parent. |
||||||
|
// |
||||||
|
// Column has various properties to control how it sizes itself and |
||||||
|
// how it positions its children. Here we use mainAxisAlignment to |
||||||
|
// center the children vertically; the main axis here is the vertical |
||||||
|
// axis because Columns are vertical (the cross axis would be |
||||||
|
// horizontal). |
||||||
|
// |
||||||
|
// TRY THIS: Invoke "debug painting" (choose the "Toggle Debug Paint" |
||||||
|
// action in the IDE, or press "p" in the console), to see the |
||||||
|
// wireframe for each widget. |
||||||
|
mainAxisAlignment: MainAxisAlignment.center, |
||||||
|
children: <Widget>[ |
||||||
|
const Text('You have pushed the button this many times:'), |
||||||
|
Text( |
||||||
|
'$_counter', |
||||||
|
style: Theme.of(context).textTheme.headlineMedium, |
||||||
|
), |
||||||
|
], |
||||||
|
), |
||||||
|
), |
||||||
|
floatingActionButton: FloatingActionButton( |
||||||
|
onPressed: _incrementCounter, |
||||||
|
tooltip: 'Increment', |
||||||
|
child: const Icon(Icons.add), |
||||||
|
), // This trailing comma makes auto-formatting nicer for build methods. |
||||||
|
); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,213 @@ |
|||||||
|
# Generated by pub |
||||||
|
# See https://dart.dev/tools/pub/glossary#lockfile |
||||||
|
packages: |
||||||
|
async: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: async |
||||||
|
sha256: d2872f9c19731c2e5f10444b14686eb7cc85c76274bd6c16e1816bff9a3bab63 |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "2.12.0" |
||||||
|
boolean_selector: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: boolean_selector |
||||||
|
sha256: "8aab1771e1243a5063b8b0ff68042d67334e3feab9e95b9490f9a6ebf73b42ea" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "2.1.2" |
||||||
|
characters: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: characters |
||||||
|
sha256: f71061c654a3380576a52b451dd5532377954cf9dbd272a78fc8479606670803 |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.4.0" |
||||||
|
clock: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: clock |
||||||
|
sha256: fddb70d9b5277016c77a80201021d40a2247104d9f4aa7bab7157b7e3f05b84b |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.1.2" |
||||||
|
collection: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: collection |
||||||
|
sha256: "2f5709ae4d3d59dd8f7cd309b4e023046b57d8a6c82130785d2b0e5868084e76" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.19.1" |
||||||
|
cupertino_icons: |
||||||
|
dependency: "direct main" |
||||||
|
description: |
||||||
|
name: cupertino_icons |
||||||
|
sha256: ba631d1c7f7bef6b729a622b7b752645a2d076dba9976925b8f25725a30e1ee6 |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.0.8" |
||||||
|
fake_async: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: fake_async |
||||||
|
sha256: "6a95e56b2449df2273fd8c45a662d6947ce1ebb7aafe80e550a3f68297f3cacc" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.3.2" |
||||||
|
flutter: |
||||||
|
dependency: "direct main" |
||||||
|
description: flutter |
||||||
|
source: sdk |
||||||
|
version: "0.0.0" |
||||||
|
flutter_lints: |
||||||
|
dependency: "direct dev" |
||||||
|
description: |
||||||
|
name: flutter_lints |
||||||
|
sha256: "5398f14efa795ffb7a33e9b6a08798b26a180edac4ad7db3f231e40f82ce11e1" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "5.0.0" |
||||||
|
flutter_test: |
||||||
|
dependency: "direct dev" |
||||||
|
description: flutter |
||||||
|
source: sdk |
||||||
|
version: "0.0.0" |
||||||
|
leak_tracker: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: leak_tracker |
||||||
|
sha256: c35baad643ba394b40aac41080300150a4f08fd0fd6a10378f8f7c6bc161acec |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "10.0.8" |
||||||
|
leak_tracker_flutter_testing: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: leak_tracker_flutter_testing |
||||||
|
sha256: f8b613e7e6a13ec79cfdc0e97638fddb3ab848452eff057653abd3edba760573 |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "3.0.9" |
||||||
|
leak_tracker_testing: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: leak_tracker_testing |
||||||
|
sha256: "6ba465d5d76e67ddf503e1161d1f4a6bc42306f9d66ca1e8f079a47290fb06d3" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "3.0.1" |
||||||
|
lints: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: lints |
||||||
|
sha256: c35bb79562d980e9a453fc715854e1ed39e24e7d0297a880ef54e17f9874a9d7 |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "5.1.1" |
||||||
|
matcher: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: matcher |
||||||
|
sha256: dc58c723c3c24bf8d3e2d3ad3f2f9d7bd9cf43ec6feaa64181775e60190153f2 |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "0.12.17" |
||||||
|
material_color_utilities: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: material_color_utilities |
||||||
|
sha256: f7142bb1154231d7ea5f96bc7bde4bda2a0945d2806bb11670e30b850d56bdec |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "0.11.1" |
||||||
|
meta: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: meta |
||||||
|
sha256: e3641ec5d63ebf0d9b41bd43201a66e3fc79a65db5f61fc181f04cd27aab950c |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.16.0" |
||||||
|
path: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: path |
||||||
|
sha256: "75cca69d1490965be98c73ceaea117e8a04dd21217b37b292c9ddbec0d955bc5" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.9.1" |
||||||
|
sky_engine: |
||||||
|
dependency: transitive |
||||||
|
description: flutter |
||||||
|
source: sdk |
||||||
|
version: "0.0.0" |
||||||
|
source_span: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: source_span |
||||||
|
sha256: "254ee5351d6cb365c859e20ee823c3bb479bf4a293c22d17a9f1bf144ce86f7c" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.10.1" |
||||||
|
stack_trace: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: stack_trace |
||||||
|
sha256: "8b27215b45d22309b5cddda1aa2b19bdfec9df0e765f2de506401c071d38d1b1" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.12.1" |
||||||
|
stream_channel: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: stream_channel |
||||||
|
sha256: "969e04c80b8bcdf826f8f16579c7b14d780458bd97f56d107d3950fdbeef059d" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "2.1.4" |
||||||
|
string_scanner: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: string_scanner |
||||||
|
sha256: "921cd31725b72fe181906c6a94d987c78e3b98c2e205b397ea399d4054872b43" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.4.1" |
||||||
|
term_glyph: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: term_glyph |
||||||
|
sha256: "7f554798625ea768a7518313e58f83891c7f5024f88e46e7182a4558850a4b8e" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "1.2.2" |
||||||
|
test_api: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: test_api |
||||||
|
sha256: fb31f383e2ee25fbbfe06b40fe21e1e458d14080e3c67e7ba0acfde4df4e0bbd |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "0.7.4" |
||||||
|
vector_math: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: vector_math |
||||||
|
sha256: "80b3257d1492ce4d091729e3a67a60407d227c27241d6927be0130c98e741803" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "2.1.4" |
||||||
|
vm_service: |
||||||
|
dependency: transitive |
||||||
|
description: |
||||||
|
name: vm_service |
||||||
|
sha256: "0968250880a6c5fe7edc067ed0a13d4bae1577fe2771dcf3010d52c4a9d3ca14" |
||||||
|
url: "https://pub.dev" |
||||||
|
source: hosted |
||||||
|
version: "14.3.1" |
||||||
|
sdks: |
||||||
|
dart: ">=3.7.0 <4.0.0" |
||||||
|
flutter: ">=3.18.0-18.0.pre.54" |
@ -0,0 +1,89 @@ |
|||||||
|
name: win_text_editor |
||||||
|
description: "A new Flutter project." |
||||||
|
# The following line prevents the package from being accidentally published to |
||||||
|
# pub.dev using `flutter pub publish`. This is preferred for private packages. |
||||||
|
publish_to: 'none' # Remove this line if you wish to publish to pub.dev |
||||||
|
|
||||||
|
# The following defines the version and build number for your application. |
||||||
|
# A version number is three numbers separated by dots, like 1.2.43 |
||||||
|
# followed by an optional build number separated by a +. |
||||||
|
# Both the version and the builder number may be overridden in flutter |
||||||
|
# build by specifying --build-name and --build-number, respectively. |
||||||
|
# In Android, build-name is used as versionName while build-number used as versionCode. |
||||||
|
# Read more about Android versioning at https://developer.android.com/studio/publish/versioning |
||||||
|
# In iOS, build-name is used as CFBundleShortVersionString while build-number is used as CFBundleVersion. |
||||||
|
# Read more about iOS versioning at |
||||||
|
# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html |
||||||
|
# In Windows, build-name is used as the major, minor, and patch parts |
||||||
|
# of the product and file versions while build-number is used as the build suffix. |
||||||
|
version: 1.0.0+1 |
||||||
|
|
||||||
|
environment: |
||||||
|
sdk: ^3.7.0 |
||||||
|
|
||||||
|
# Dependencies specify other packages that your package needs in order to work. |
||||||
|
# To automatically upgrade your package dependencies to the latest versions |
||||||
|
# consider running `flutter pub upgrade --major-versions`. Alternatively, |
||||||
|
# dependencies can be manually updated by changing the version numbers below to |
||||||
|
# the latest version available on pub.dev. To see which dependencies have newer |
||||||
|
# versions available, run `flutter pub outdated`. |
||||||
|
dependencies: |
||||||
|
flutter: |
||||||
|
sdk: flutter |
||||||
|
|
||||||
|
# The following adds the Cupertino Icons font to your application. |
||||||
|
# Use with the CupertinoIcons class for iOS style icons. |
||||||
|
cupertino_icons: ^1.0.8 |
||||||
|
|
||||||
|
dev_dependencies: |
||||||
|
flutter_test: |
||||||
|
sdk: flutter |
||||||
|
|
||||||
|
# The "flutter_lints" package below contains a set of recommended lints to |
||||||
|
# encourage good coding practices. The lint set provided by the package is |
||||||
|
# activated in the `analysis_options.yaml` file located at the root of your |
||||||
|
# package. See that file for information about deactivating specific lint |
||||||
|
# rules and activating additional ones. |
||||||
|
flutter_lints: ^5.0.0 |
||||||
|
|
||||||
|
# For information on the generic Dart part of this file, see the |
||||||
|
# following page: https://dart.dev/tools/pub/pubspec |
||||||
|
|
||||||
|
# The following section is specific to Flutter packages. |
||||||
|
flutter: |
||||||
|
|
||||||
|
# The following line ensures that the Material Icons font is |
||||||
|
# included with your application, so that you can use the icons in |
||||||
|
# the material Icons class. |
||||||
|
uses-material-design: true |
||||||
|
|
||||||
|
# To add assets to your application, add an assets section, like this: |
||||||
|
# assets: |
||||||
|
# - images/a_dot_burr.jpeg |
||||||
|
# - images/a_dot_ham.jpeg |
||||||
|
|
||||||
|
# An image asset can refer to one or more resolution-specific "variants", see |
||||||
|
# https://flutter.dev/to/resolution-aware-images |
||||||
|
|
||||||
|
# For details regarding adding assets from package dependencies, see |
||||||
|
# https://flutter.dev/to/asset-from-package |
||||||
|
|
||||||
|
# To add custom fonts to your application, add a fonts section here, |
||||||
|
# in this "flutter" section. Each entry in this list should have a |
||||||
|
# "family" key with the font family name, and a "fonts" key with a |
||||||
|
# list giving the asset and other descriptors for the font. For |
||||||
|
# example: |
||||||
|
# fonts: |
||||||
|
# - family: Schyler |
||||||
|
# fonts: |
||||||
|
# - asset: fonts/Schyler-Regular.ttf |
||||||
|
# - asset: fonts/Schyler-Italic.ttf |
||||||
|
# style: italic |
||||||
|
# - family: Trajan Pro |
||||||
|
# fonts: |
||||||
|
# - asset: fonts/TrajanPro.ttf |
||||||
|
# - asset: fonts/TrajanPro_Bold.ttf |
||||||
|
# weight: 700 |
||||||
|
# |
||||||
|
# For details regarding fonts from package dependencies, |
||||||
|
# see https://flutter.dev/to/font-from-package |
@ -0,0 +1,30 @@ |
|||||||
|
// This is a basic Flutter widget test. |
||||||
|
// |
||||||
|
// To perform an interaction with a widget in your test, use the WidgetTester |
||||||
|
// utility in the flutter_test package. For example, you can send tap and scroll |
||||||
|
// gestures. You can also use WidgetTester to find child widgets in the widget |
||||||
|
// tree, read text, and verify that the values of widget properties are correct. |
||||||
|
|
||||||
|
import 'package:flutter/material.dart'; |
||||||
|
import 'package:flutter_test/flutter_test.dart'; |
||||||
|
|
||||||
|
import 'package:win_text_editor/main.dart'; |
||||||
|
|
||||||
|
void main() { |
||||||
|
testWidgets('Counter increments smoke test', (WidgetTester tester) async { |
||||||
|
// Build our app and trigger a frame. |
||||||
|
await tester.pumpWidget(const MyApp()); |
||||||
|
|
||||||
|
// Verify that our counter starts at 0. |
||||||
|
expect(find.text('0'), findsOneWidget); |
||||||
|
expect(find.text('1'), findsNothing); |
||||||
|
|
||||||
|
// Tap the '+' icon and trigger a frame. |
||||||
|
await tester.tap(find.byIcon(Icons.add)); |
||||||
|
await tester.pump(); |
||||||
|
|
||||||
|
// Verify that our counter has incremented. |
||||||
|
expect(find.text('0'), findsNothing); |
||||||
|
expect(find.text('1'), findsOneWidget); |
||||||
|
}); |
||||||
|
} |
@ -0,0 +1,17 @@ |
|||||||
|
flutter/ephemeral/ |
||||||
|
|
||||||
|
# Visual Studio user-specific files. |
||||||
|
*.suo |
||||||
|
*.user |
||||||
|
*.userosscache |
||||||
|
*.sln.docstates |
||||||
|
|
||||||
|
# Visual Studio build-related files. |
||||||
|
x64/ |
||||||
|
x86/ |
||||||
|
|
||||||
|
# Visual Studio cache files |
||||||
|
# files ending in .cache can be ignored |
||||||
|
*.[Cc]ache |
||||||
|
# but keep track of directories ending in .cache |
||||||
|
!*.[Cc]ache/ |
@ -0,0 +1,108 @@ |
|||||||
|
# Project-level configuration. |
||||||
|
cmake_minimum_required(VERSION 3.14) |
||||||
|
project(win_text_editor LANGUAGES CXX) |
||||||
|
|
||||||
|
# The name of the executable created for the application. Change this to change |
||||||
|
# the on-disk name of your application. |
||||||
|
set(BINARY_NAME "win_text_editor") |
||||||
|
|
||||||
|
# Explicitly opt in to modern CMake behaviors to avoid warnings with recent |
||||||
|
# versions of CMake. |
||||||
|
cmake_policy(VERSION 3.14...3.25) |
||||||
|
|
||||||
|
# Define build configuration option. |
||||||
|
get_property(IS_MULTICONFIG GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG) |
||||||
|
if(IS_MULTICONFIG) |
||||||
|
set(CMAKE_CONFIGURATION_TYPES "Debug;Profile;Release" |
||||||
|
CACHE STRING "" FORCE) |
||||||
|
else() |
||||||
|
if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) |
||||||
|
set(CMAKE_BUILD_TYPE "Debug" CACHE |
||||||
|
STRING "Flutter build mode" FORCE) |
||||||
|
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS |
||||||
|
"Debug" "Profile" "Release") |
||||||
|
endif() |
||||||
|
endif() |
||||||
|
# Define settings for the Profile build mode. |
||||||
|
set(CMAKE_EXE_LINKER_FLAGS_PROFILE "${CMAKE_EXE_LINKER_FLAGS_RELEASE}") |
||||||
|
set(CMAKE_SHARED_LINKER_FLAGS_PROFILE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE}") |
||||||
|
set(CMAKE_C_FLAGS_PROFILE "${CMAKE_C_FLAGS_RELEASE}") |
||||||
|
set(CMAKE_CXX_FLAGS_PROFILE "${CMAKE_CXX_FLAGS_RELEASE}") |
||||||
|
|
||||||
|
# Use Unicode for all projects. |
||||||
|
add_definitions(-DUNICODE -D_UNICODE) |
||||||
|
|
||||||
|
# Compilation settings that should be applied to most targets. |
||||||
|
# |
||||||
|
# Be cautious about adding new options here, as plugins use this function by |
||||||
|
# default. In most cases, you should add new options to specific targets instead |
||||||
|
# of modifying this function. |
||||||
|
function(APPLY_STANDARD_SETTINGS TARGET) |
||||||
|
target_compile_features(${TARGET} PUBLIC cxx_std_17) |
||||||
|
target_compile_options(${TARGET} PRIVATE /W4 /WX /wd"4100") |
||||||
|
target_compile_options(${TARGET} PRIVATE /EHsc) |
||||||
|
target_compile_definitions(${TARGET} PRIVATE "_HAS_EXCEPTIONS=0") |
||||||
|
target_compile_definitions(${TARGET} PRIVATE "$<$<CONFIG:Debug>:_DEBUG>") |
||||||
|
endfunction() |
||||||
|
|
||||||
|
# Flutter library and tool build rules. |
||||||
|
set(FLUTTER_MANAGED_DIR "${CMAKE_CURRENT_SOURCE_DIR}/flutter") |
||||||
|
add_subdirectory(${FLUTTER_MANAGED_DIR}) |
||||||
|
|
||||||
|
# Application build; see runner/CMakeLists.txt. |
||||||
|
add_subdirectory("runner") |
||||||
|
|
||||||
|
|
||||||
|
# Generated plugin build rules, which manage building the plugins and adding |
||||||
|
# them to the application. |
||||||
|
include(flutter/generated_plugins.cmake) |
||||||
|
|
||||||
|
|
||||||
|
# === Installation === |
||||||
|
# Support files are copied into place next to the executable, so that it can |
||||||
|
# run in place. This is done instead of making a separate bundle (as on Linux) |
||||||
|
# so that building and running from within Visual Studio will work. |
||||||
|
set(BUILD_BUNDLE_DIR "$<TARGET_FILE_DIR:${BINARY_NAME}>") |
||||||
|
# Make the "install" step default, as it's required to run. |
||||||
|
set(CMAKE_VS_INCLUDE_INSTALL_TO_DEFAULT_BUILD 1) |
||||||
|
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) |
||||||
|
set(CMAKE_INSTALL_PREFIX "${BUILD_BUNDLE_DIR}" CACHE PATH "..." FORCE) |
||||||
|
endif() |
||||||
|
|
||||||
|
set(INSTALL_BUNDLE_DATA_DIR "${CMAKE_INSTALL_PREFIX}/data") |
||||||
|
set(INSTALL_BUNDLE_LIB_DIR "${CMAKE_INSTALL_PREFIX}") |
||||||
|
|
||||||
|
install(TARGETS ${BINARY_NAME} RUNTIME DESTINATION "${CMAKE_INSTALL_PREFIX}" |
||||||
|
COMPONENT Runtime) |
||||||
|
|
||||||
|
install(FILES "${FLUTTER_ICU_DATA_FILE}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" |
||||||
|
COMPONENT Runtime) |
||||||
|
|
||||||
|
install(FILES "${FLUTTER_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" |
||||||
|
COMPONENT Runtime) |
||||||
|
|
||||||
|
if(PLUGIN_BUNDLED_LIBRARIES) |
||||||
|
install(FILES "${PLUGIN_BUNDLED_LIBRARIES}" |
||||||
|
DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" |
||||||
|
COMPONENT Runtime) |
||||||
|
endif() |
||||||
|
|
||||||
|
# Copy the native assets provided by the build.dart from all packages. |
||||||
|
set(NATIVE_ASSETS_DIR "${PROJECT_BUILD_DIR}native_assets/windows/") |
||||||
|
install(DIRECTORY "${NATIVE_ASSETS_DIR}" |
||||||
|
DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" |
||||||
|
COMPONENT Runtime) |
||||||
|
|
||||||
|
# Fully re-copy the assets directory on each build to avoid having stale files |
||||||
|
# from a previous install. |
||||||
|
set(FLUTTER_ASSET_DIR_NAME "flutter_assets") |
||||||
|
install(CODE " |
||||||
|
file(REMOVE_RECURSE \"${INSTALL_BUNDLE_DATA_DIR}/${FLUTTER_ASSET_DIR_NAME}\") |
||||||
|
" COMPONENT Runtime) |
||||||
|
install(DIRECTORY "${PROJECT_BUILD_DIR}/${FLUTTER_ASSET_DIR_NAME}" |
||||||
|
DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" COMPONENT Runtime) |
||||||
|
|
||||||
|
# Install the AOT library on non-Debug builds only. |
||||||
|
install(FILES "${AOT_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" |
||||||
|
CONFIGURATIONS Profile;Release |
||||||
|
COMPONENT Runtime) |
@ -0,0 +1,109 @@ |
|||||||
|
# This file controls Flutter-level build steps. It should not be edited. |
||||||
|
cmake_minimum_required(VERSION 3.14) |
||||||
|
|
||||||
|
set(EPHEMERAL_DIR "${CMAKE_CURRENT_SOURCE_DIR}/ephemeral") |
||||||
|
|
||||||
|
# Configuration provided via flutter tool. |
||||||
|
include(${EPHEMERAL_DIR}/generated_config.cmake) |
||||||
|
|
||||||
|
# TODO: Move the rest of this into files in ephemeral. See |
||||||
|
# https://github.com/flutter/flutter/issues/57146. |
||||||
|
set(WRAPPER_ROOT "${EPHEMERAL_DIR}/cpp_client_wrapper") |
||||||
|
|
||||||
|
# Set fallback configurations for older versions of the flutter tool. |
||||||
|
if (NOT DEFINED FLUTTER_TARGET_PLATFORM) |
||||||
|
set(FLUTTER_TARGET_PLATFORM "windows-x64") |
||||||
|
endif() |
||||||
|
|
||||||
|
# === Flutter Library === |
||||||
|
set(FLUTTER_LIBRARY "${EPHEMERAL_DIR}/flutter_windows.dll") |
||||||
|
|
||||||
|
# Published to parent scope for install step. |
||||||
|
set(FLUTTER_LIBRARY ${FLUTTER_LIBRARY} PARENT_SCOPE) |
||||||
|
set(FLUTTER_ICU_DATA_FILE "${EPHEMERAL_DIR}/icudtl.dat" PARENT_SCOPE) |
||||||
|
set(PROJECT_BUILD_DIR "${PROJECT_DIR}/build/" PARENT_SCOPE) |
||||||
|
set(AOT_LIBRARY "${PROJECT_DIR}/build/windows/app.so" PARENT_SCOPE) |
||||||
|
|
||||||
|
list(APPEND FLUTTER_LIBRARY_HEADERS |
||||||
|
"flutter_export.h" |
||||||
|
"flutter_windows.h" |
||||||
|
"flutter_messenger.h" |
||||||
|
"flutter_plugin_registrar.h" |
||||||
|
"flutter_texture_registrar.h" |
||||||
|
) |
||||||
|
list(TRANSFORM FLUTTER_LIBRARY_HEADERS PREPEND "${EPHEMERAL_DIR}/") |
||||||
|
add_library(flutter INTERFACE) |
||||||
|
target_include_directories(flutter INTERFACE |
||||||
|
"${EPHEMERAL_DIR}" |
||||||
|
) |
||||||
|
target_link_libraries(flutter INTERFACE "${FLUTTER_LIBRARY}.lib") |
||||||
|
add_dependencies(flutter flutter_assemble) |
||||||
|
|
||||||
|
# === Wrapper === |
||||||
|
list(APPEND CPP_WRAPPER_SOURCES_CORE |
||||||
|
"core_implementations.cc" |
||||||
|
"standard_codec.cc" |
||||||
|
) |
||||||
|
list(TRANSFORM CPP_WRAPPER_SOURCES_CORE PREPEND "${WRAPPER_ROOT}/") |
||||||
|
list(APPEND CPP_WRAPPER_SOURCES_PLUGIN |
||||||
|
"plugin_registrar.cc" |
||||||
|
) |
||||||
|
list(TRANSFORM CPP_WRAPPER_SOURCES_PLUGIN PREPEND "${WRAPPER_ROOT}/") |
||||||
|
list(APPEND CPP_WRAPPER_SOURCES_APP |
||||||
|
"flutter_engine.cc" |
||||||
|
"flutter_view_controller.cc" |
||||||
|
) |
||||||
|
list(TRANSFORM CPP_WRAPPER_SOURCES_APP PREPEND "${WRAPPER_ROOT}/") |
||||||
|
|
||||||
|
# Wrapper sources needed for a plugin. |
||||||
|
add_library(flutter_wrapper_plugin STATIC |
||||||
|
${CPP_WRAPPER_SOURCES_CORE} |
||||||
|
${CPP_WRAPPER_SOURCES_PLUGIN} |
||||||
|
) |
||||||
|
apply_standard_settings(flutter_wrapper_plugin) |
||||||
|
set_target_properties(flutter_wrapper_plugin PROPERTIES |
||||||
|
POSITION_INDEPENDENT_CODE ON) |
||||||
|
set_target_properties(flutter_wrapper_plugin PROPERTIES |
||||||
|
CXX_VISIBILITY_PRESET hidden) |
||||||
|
target_link_libraries(flutter_wrapper_plugin PUBLIC flutter) |
||||||
|
target_include_directories(flutter_wrapper_plugin PUBLIC |
||||||
|
"${WRAPPER_ROOT}/include" |
||||||
|
) |
||||||
|
add_dependencies(flutter_wrapper_plugin flutter_assemble) |
||||||
|
|
||||||
|
# Wrapper sources needed for the runner. |
||||||
|
add_library(flutter_wrapper_app STATIC |
||||||
|
${CPP_WRAPPER_SOURCES_CORE} |
||||||
|
${CPP_WRAPPER_SOURCES_APP} |
||||||
|
) |
||||||
|
apply_standard_settings(flutter_wrapper_app) |
||||||
|
target_link_libraries(flutter_wrapper_app PUBLIC flutter) |
||||||
|
target_include_directories(flutter_wrapper_app PUBLIC |
||||||
|
"${WRAPPER_ROOT}/include" |
||||||
|
) |
||||||
|
add_dependencies(flutter_wrapper_app flutter_assemble) |
||||||
|
|
||||||
|
# === Flutter tool backend === |
||||||
|
# _phony_ is a non-existent file to force this command to run every time, |
||||||
|
# since currently there's no way to get a full input/output list from the |
||||||
|
# flutter tool. |
||||||
|
set(PHONY_OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/_phony_") |
||||||
|
set_source_files_properties("${PHONY_OUTPUT}" PROPERTIES SYMBOLIC TRUE) |
||||||
|
add_custom_command( |
||||||
|
OUTPUT ${FLUTTER_LIBRARY} ${FLUTTER_LIBRARY_HEADERS} |
||||||
|
${CPP_WRAPPER_SOURCES_CORE} ${CPP_WRAPPER_SOURCES_PLUGIN} |
||||||
|
${CPP_WRAPPER_SOURCES_APP} |
||||||
|
${PHONY_OUTPUT} |
||||||
|
COMMAND ${CMAKE_COMMAND} -E env |
||||||
|
${FLUTTER_TOOL_ENVIRONMENT} |
||||||
|
"${FLUTTER_ROOT}/packages/flutter_tools/bin/tool_backend.bat" |
||||||
|
${FLUTTER_TARGET_PLATFORM} $<CONFIG> |
||||||
|
VERBATIM |
||||||
|
) |
||||||
|
add_custom_target(flutter_assemble DEPENDS |
||||||
|
"${FLUTTER_LIBRARY}" |
||||||
|
${FLUTTER_LIBRARY_HEADERS} |
||||||
|
${CPP_WRAPPER_SOURCES_CORE} |
||||||
|
${CPP_WRAPPER_SOURCES_PLUGIN} |
||||||
|
${CPP_WRAPPER_SOURCES_APP} |
||||||
|
) |
@ -0,0 +1,11 @@ |
|||||||
|
//
|
||||||
|
// Generated file. Do not edit.
|
||||||
|
//
|
||||||
|
|
||||||
|
// clang-format off
|
||||||
|
|
||||||
|
#include "generated_plugin_registrant.h" |
||||||
|
|
||||||
|
|
||||||
|
void RegisterPlugins(flutter::PluginRegistry* registry) { |
||||||
|
} |
@ -0,0 +1,15 @@ |
|||||||
|
//
|
||||||
|
// Generated file. Do not edit.
|
||||||
|
//
|
||||||
|
|
||||||
|
// clang-format off
|
||||||
|
|
||||||
|
#ifndef GENERATED_PLUGIN_REGISTRANT_ |
||||||
|
#define GENERATED_PLUGIN_REGISTRANT_ |
||||||
|
|
||||||
|
#include <flutter/plugin_registry.h> |
||||||
|
|
||||||
|
// Registers Flutter plugins.
|
||||||
|
void RegisterPlugins(flutter::PluginRegistry* registry); |
||||||
|
|
||||||
|
#endif // GENERATED_PLUGIN_REGISTRANT_
|
@ -0,0 +1,23 @@ |
|||||||
|
# |
||||||
|
# Generated file, do not edit. |
||||||
|
# |
||||||
|
|
||||||
|
list(APPEND FLUTTER_PLUGIN_LIST |
||||||
|
) |
||||||
|
|
||||||
|
list(APPEND FLUTTER_FFI_PLUGIN_LIST |
||||||
|
) |
||||||
|
|
||||||
|
set(PLUGIN_BUNDLED_LIBRARIES) |
||||||
|
|
||||||
|
foreach(plugin ${FLUTTER_PLUGIN_LIST}) |
||||||
|
add_subdirectory(flutter/ephemeral/.plugin_symlinks/${plugin}/windows plugins/${plugin}) |
||||||
|
target_link_libraries(${BINARY_NAME} PRIVATE ${plugin}_plugin) |
||||||
|
list(APPEND PLUGIN_BUNDLED_LIBRARIES $<TARGET_FILE:${plugin}_plugin>) |
||||||
|
list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${plugin}_bundled_libraries}) |
||||||
|
endforeach(plugin) |
||||||
|
|
||||||
|
foreach(ffi_plugin ${FLUTTER_FFI_PLUGIN_LIST}) |
||||||
|
add_subdirectory(flutter/ephemeral/.plugin_symlinks/${ffi_plugin}/windows plugins/${ffi_plugin}) |
||||||
|
list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${ffi_plugin}_bundled_libraries}) |
||||||
|
endforeach(ffi_plugin) |
Loading…
Reference in new issue