24 changed files with 878 additions and 4365 deletions
@ -1 +1,8 @@
@@ -1 +1,8 @@
|
||||
/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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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 @@
@@ -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