当前位置: 首页 > article >正文

【typst-rs】greet.rs文件

以下是对greet.rs的详细解析。usestd::io::{self,Read};/// This is shown to users who just type typst the first time.#[rustfmt::skip]constGREETING:strcolor_print::cstr!(\ sWelcome to Typst, we are glad to have you here!/ ❤️ If you are new to Typst, sstart with the tutorial/ at \ uhttps://typst.app/docs/tutorial//. To get a quick start with your first \ project, schoose a template/ on uhttps://typst.app/universe//. Here are the smost important commands/ you will be using: - Compile a file once: c!typst compile file.typ/ - Compile a file on every change: c!typst watch file.typ/ - Set up a project from a template: c!typst init preview/TEMPLATE/ Learn more about these commands by running c!typst help/. If you have a question, we and our community would be glad to help you out on \ the sTypst Forum/ at uhttps://forum.typst.app//. Happy Typsting! );/// Greets (and exists) if not yet greeted.pubfngreet(){letSome(data_dir)dirs::data_dir()else{return};letpathdata_dir.join(typst).join(greeted);letversiontypst::utils::version().raw();letprev_greetstd::fs::read_to_string(path).ok();ifprev_greet.as_deref()Some(version){return;};std::fs::write(path,version).ok();print_and_exit(GREETING);}/// Prints a colorized and line-wrapped message.fnprint_and_exit(message:staticstr)-!{// Abuse clap for line wrapping ...leterrclap::Command::new(typst).max_term_width(80).help_template({about}).about(message).try_get_matches_from([typst,--help]).unwrap_err();let_err.print();// Windows users might have double-clicked the .exe file and have no chance// to read it before the terminal closes.ifcfg!(windows){pause();}std::process::exit(err.exit_code());}/// Waits for the user.#[allow(clippy::unused_io_amount)]fnpause(){eprintln!();eprintln!(Press enter to continue...);io::stdin().lock().read(mut[0]).unwrap();}代码功能概述这段代码是Typst 编译器的首次启动欢迎模块。其主要功能是当用户首次运行typst命令时显示一条彩色、格式友好的欢迎信息并记录已展示过该信息避免重复显示。详细解析1. 常量GREETING实现使用color_print::cstr!宏在编译时生成带 ANSI 颜色/样式标签的字符串。样式标签s表示加粗或高亮样式。c!表示命令样式通常显示为青色或加粗。u表示下划线样式。内容包含欢迎语、官方教程链接、常用命令示例以及社区论坛地址。2.greet()函数这是模块的公共入口函数执行以下步骤获取数据目录通过dirs::data_dir()获取操作系统的用户数据目录例如 Linux 下的~/.local/shareWindows 下的%APPDATA%。构建状态文件路径拼接为数据目录/typst/greeted用于记录已向用户显示过欢迎信息。获取当前版本号调用typst::utils::version().raw()获取当前 Typst 版本的原始字符串。检查是否已欢迎尝试读取greeted文件的内容。如果文件内容与当前版本号一致说明当前版本已显示过欢迎信息函数直接返回不再重复显示。首次运行或版本更新将当前版本号写入greeted文件。调用print_and_exit(GREETING)显示欢迎信息并退出程序。3.print_and_exit()函数该函数负责格式化并输出欢迎信息然后退出程序利用 clap 库进行格式化创建一个临时的clap::Command设置最大宽度为 80 列将help_template设为{about}并通过.about(message)将欢迎信息作为帮助文本。调用.try_get_matches_from([typst, --help])强制触发--help解析产生一个错误对象。从错误对象中获取已格式化好的帮助文本并打印到终端。Windows 平台特殊处理通过cfg!(windows)条件编译在 Windows 系统上调用pause()函数等待用户按键后窗口才关闭避免双击 .exe 文件时终端一闪而过。退出程序使用std::process::exit()退出退出码来自 clap 错误对象。4.pause()函数仅在 Windows 平台被调用功能是等待用户输入输出换行和提示信息Press enter to continue...。锁定标准输入读取 1 字节数据用户按下的回车键\n忽略实际读取的内容。#[allow(clippy::unused_io_amount)]属性用于抑制 Clippy 关于未检查读取字节数的警告。总体执行流程用户首次运行typst命令 → 调用greet()函数。检查~/.local/share/typst/greeted或 Windows 对应路径中是否包含当前版本号。如果文件不存在或内容与当前版本号不匹配将当前版本号写入该文件。显示彩色欢迎信息宽度 80 列自动换行。在 Windows 系统上等待用户按键。退出程序在正常执行流程中此退出会阻止后续命令执行实际上这里的设计是如果显示欢迎信息程序就退出如果已欢迎过则静默返回继续执行其他逻辑例如显示帮助或编译文档。如果已欢迎过且版本未变 → 静默返回程序继续正常执行。设计亮点版本感知版本升级后会自动重新显示欢迎信息确保用户了解新版本的特性或重要提示。跨平台兼容使用dirs库获取标准数据目录并对 Windows 平台做了特殊的暂停处理。代码复用巧妙借用clap库的终端格式化能力避免手动实现换行和颜色处理。优雅退出print_and_exit函数返回类型为!发散函数表示不会正常返回意图明确。潜在问题输出语义混淆err.print()会将内容输出到stderr但欢迎信息通常应输出到stdout这在语义上略有混淆。实现方式巧妙但略为 Hack利用clap的--help错误来格式化文本虽然巧妙但不是最直观的解决方案。自定义修改建议如需修改欢迎信息直接编辑GREETING常量即可。如需调整终端输出宽度修改print_and_exit函数中的.max_term_width(80)参数。如需改变状态文件存储位置修改path的构建方式。

相关文章:

【typst-rs】greet.rs文件

以下是对greet.rs的详细解析。 use std::io::{self, Read};/// This is shown to users who just type typst the first time. #[rustfmt::skip] const GREETING: &str color_print::cstr!("\ <s>Welcome to Typst, we are glad to have you here!</> ❤…...

嵌入式系统软件抗干扰技术实战解析

1. 嵌入式系统抗干扰技术概述在工业控制、智能家居和物联网设备等嵌入式应用场景中&#xff0c;电磁干扰、电源波动等环境因素常常导致系统运行异常。作为一名有十年嵌入式开发经验的工程师&#xff0c;我处理过数十起由干扰引起的系统故障案例。硬件抗干扰措施如屏蔽、滤波固然…...

从《节奏医生》到你的游戏:拆解Koreographer Pro版如何实现高级音频集成(Wwise/FMOD)

从《节奏医生》到你的游戏&#xff1a;Koreographer Pro版如何实现高级音频集成&#xff08;Wwise/FMOD&#xff09; 在《节奏医生》这类音游中&#xff0c;玩家按键与音乐节拍的完美同步是游戏体验的核心。这种精准的音频同步背后&#xff0c;往往需要复杂的音频中间件集成。对…...

I2C总线原理与应用实战指南

1. I2C总线基础概念解析I2C&#xff08;Inter-Integrated Circuit&#xff09;总线是飞利浦半导体&#xff08;现NXP&#xff09;在1980年代开发的一种同步、多主从架构的串行通信总线。作为一名嵌入式工程师&#xff0c;我几乎在每个项目中都会用到这个看似简单却功能强大的两…...

从零开始:在RK3588上运行RKNN版YOLOv5目标检测(保姆级教程)

从零开始&#xff1a;在RK3588上运行RKNN版YOLOv5目标检测&#xff08;保姆级教程&#xff09; RK3588作为Rockchip新一代旗舰级SoC&#xff0c;其内置的NPU模块为边缘计算场景提供了强大的AI推理能力。本教程将手把手带您完成YOLOv5目标检测模型在RK3588开发板上的完整部署流程…...

显示器EDID数据解析全攻略:从制造商ID到色彩特性的秘密

显示器EDID数据解析全攻略&#xff1a;从制造商ID到色彩特性的秘密 当你连接一台新显示器时&#xff0c;操作系统是如何知道它的最佳分辨率和刷新率的&#xff1f;答案就藏在EDID&#xff08;Extended Display Identification Data&#xff09;这个小小的数据块中。EDID是显示器…...

ESP32伺服与PWM控制库:硬件自适应资源管理

1. 项目概述ESP32ServoController 是一款专为 ESP32 系列微控制器设计的高性能 PWM 与伺服控制库。它并非对 Espressif 官方 LEDC&#xff08;LED Control&#xff09;外设驱动的简单封装&#xff0c;而是基于其硬件架构进行深度抽象与工程化重构的底层控制框架。该库的核心设计…...

双Token无感刷新:从登录到重试的完整链路解析

1. 双Token机制的核心原理 想象一下你住在一个高档小区&#xff0c;门禁卡就是你的通行证。普通门禁卡&#xff08;Access Token&#xff09;有效期只有30分钟&#xff0c;而物业还给你一张备用卡&#xff08;Refresh Token&#xff09;有效期长达7天。当普通卡过期时&#xff…...

2025届必备的五大AI辅助写作工具解析与推荐

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 目前&#xff0c;在学术论文以及职场报告等这些内容生产场景当中&#xff0c;对于文本原创性…...

一道KMP统考真题彻底讲透:nextval与滑动距离的本质我

一、各自优势和对比 这是检索出来的数据&#xff0c;据说是根据第三方评测与企业数据&#xff0c;三款产品在代码生成质量上各有侧重&#xff1a; 产品 语言优势 场景亮点 核心差异 百度 Comate C核心代码质量第一&#xff1b;Python首生成率达92.3% SQL生成准确率提升35%&…...

零基础玩转OpenClaw:Qwen2.5-VL-7B多模态模型入门指南

零基础玩转OpenClaw&#xff1a;Qwen2.5-VL-7B多模态模型入门指南 1. 为什么选择OpenClawQwen2.5-VL组合 去年夏天&#xff0c;当我第一次看到同事用自然语言指令让AI自动整理会议纪要时&#xff0c;内心受到了巨大冲击。经过两周的折腾&#xff0c;我终于在自己的MacBook上搭…...

YOLO11 改进 - 特征融合 | MSAA多尺度注意力聚合模块, 多尺度卷积融合与双通道注意力机制

前言 本文介绍了将多尺度注意力聚合(MSAA)模块与YOLO11结合的方法。MSAA是CM - UNet中用于优化编码器特征、强化跳跃连接的核心模块,能解决遥感图像物体尺度差异大、多尺度特征融合弱的问题。它采用空间与通道双分支并行处理,先对输入的相邻三层特征进行拼接,再分别进行空…...

YOLO26改进 - 注意力机制 | EMA (Efficient Multi-Scale Attention) 高效多尺度注意力:跨空间学习与多分支协同增强特征表征,优化多尺度目标检测

前言 本文介绍了高效多尺度注意力(EMA)模块及其在YOLO26中的结合应用。现有注意力机制在通道维度缩减时可能影响深度视觉表示,EMA模块通过结合通道和空间信息、采用多尺度并行子网络结构等创新点,实现了高效的多尺度注意力机制。其基本原理包括通道和空间注意力结合、多尺…...

嵌入式舵机精确控制:基于硬件定时器的PWM脉宽稳定实现

1. Servo库技术解析&#xff1a;面向嵌入式系统的单路舵机精确控制实现1.1 库定位与工程价值Servo库是一个轻量级、面向资源受限嵌入式平台的单路舵机控制库。其核心设计哲学并非追求功能堆砌&#xff0c;而是聚焦于时间精度、脉宽稳定性与硬件抽象解耦三大关键指标。在STM32F0…...

职场人AI生存指南:10个核心技能,让你不被AI淘汰反而被赋能

掌握AI工具的基础应用职场人需要熟悉主流AI工具的操作&#xff0c;如ChatGPT、Copilot、Notion AI等。了解这些工具的基本功能&#xff0c;如文本生成、数据分析、自动化流程等&#xff0c;能够提升工作效率。定期关注AI工具的更新&#xff0c;学习新功能的应用场景。培养数据思…...

打工人必备!8个AI办公神器,每天准时下班不是梦

文档处理工具Notion AI 集成在Notion中的AI功能&#xff0c;支持自动生成文档大纲、会议纪要整理、多语言翻译。通过自然语言输入需求&#xff0c;快速输出结构化内容&#xff0c;适合项目管理与知识库搭建。ChatPDF 上传PDF文件后可直接对话式提问&#xff0c;提取关键信息或总…...

从PyTorch到FPGA:手把手教你将MobileNetV2模型部署到Zynq平台(附完整代码)

从PyTorch到FPGA&#xff1a;手把手教你将MobileNetV2模型部署到Zynq平台&#xff08;附完整代码&#xff09; 在边缘计算领域&#xff0c;FPGA因其低延迟、高能效和可重构特性&#xff0c;正成为轻量级CNN模型部署的理想选择。本文将带您完成一个从PyTorch模型训练到Xilinx Zy…...

嵌入式C语言设计模式实践:观察者与责任链模式

1. 嵌入式软件开发中的设计模式应用背景在传统认知中&#xff0c;嵌入式系统开发往往与"资源受限"、"底层硬件"、"效率优先"等标签紧密关联。早期的嵌入式设备功能单一&#xff0c;业务逻辑简单&#xff0c;开发者更关注代码的执行效率和硬件资源…...

STM32duino双VL6180X ToF传感器驱动库深度解析

1. 项目概述STM32duino X-NUCLEO-6180XA1 是一个面向 Arduino 兼容生态&#xff08;特别是基于 STM32 的开发板&#xff0c;如 NUCLEO-F401RE、NUCLEO-F411RE、NUCLEO-L476RG 等&#xff09;的硬件抽象库&#xff0c;专为驱动意法半导体&#xff08;STMicroelectronics&#xf…...

【渗透工具】Venom多级代理实战:从零构建内网渗透通道

1. Venom工具入门&#xff1a;多级代理的核心价值 第一次接触Venom是在去年的一次内网渗透项目中。当时客户的内网结构复杂&#xff0c;常规代理工具难以穿透多层网络&#xff0c;直到同事推荐了这个用Go语言开发的神器。简单来说&#xff0c;Venom就像个数字隧道挖掘机&#x…...

嵌入式裸机开发中的轻量级定时调度方案

1. SmartTimer&#xff1a;裸机环境下的轻量级定时调度方案在嵌入式开发中&#xff0c;定时任务管理是个永恒的话题。我最近在做一个空气质量监测项目时&#xff0c;发现传统的裸机编程方式在处理多个定时任务时显得力不从心。硬件定时器资源有限&#xff0c;软件标志位管理又容…...

6000万吨产能承压 卫星化学迎来战略窗口期

据新华社报道&#xff0c;伊朗法尔斯通讯社7日凌晨援引未具名消息源报道&#xff0c;沙特阿拉伯东北部朱拜勒工业区当天发生爆炸&#xff0c;系遭到大范围打击。据悉&#xff0c;朱拜勒工业区是全球重要石化生产基地之一&#xff0c;年产量约6000万吨石化产品&#xff0c;占全球…...

10个经典C语言开源项目深度解析

1. 精选C语言开源项目解析作为一名在系统级编程领域摸爬滚打多年的开发者&#xff0c;我深知优秀的C语言项目对技术成长的帮助。今天要分享的这10个项目&#xff0c;每个都是经过时间检验的经典之作&#xff0c;代码量控制在3万行以内&#xff0c;特别适合作为学习范本。这些项…...

2026届必备的十大AI科研网站解析与推荐

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 伴随人工智能技术的迅猛发展&#xff0c;AI论文工具已然成为学术写作范畴的关键辅助方式&…...

2025最权威的六大AI论文神器实际效果

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 关于论文一键生成的技术&#xff0c;它借助了先进的自动化算法&#xff0c;还有自然语言处理…...

用好AI的五个习惯

五个习惯一、善于拆解问题核心逻辑&#xff1a;AI是执行者&#xff0c;人是设计者。对项目的全流程和细节了如指掌&#xff0c;能够将复杂的大问题拆解为具体的、AI可执行的子任务。二、上下文管理大师核心逻辑&#xff1a;理解模型极限&#xff0c;追求高效输出。当前AI模型&a…...

STM32 GPIO工作模式详解与应用指南

1. STM32 GPIO工作模式深度解析作为一名嵌入式开发工程师&#xff0c;我经常需要与STM32的GPIO打交道。GPIO&#xff08;General Purpose Input/Output&#xff09;作为单片机最基础也最常用的外设&#xff0c;其工作模式的选择直接影响着系统稳定性和功能实现。今天我将结合自…...

MultiSerial:单UART多通道串行通信复用库

1. 项目概述MultiSerial 是一个面向嵌入式系统的多字节串行通信抽象库&#xff0c;其核心设计目标是在单个物理串口&#xff08;UART/USART&#xff09;上安全、可靠地复用多个逻辑通信通道&#xff0c;实现“一串口多路数据流”的工程需求。该库不依赖特定硬件平台或RTOS&…...

新质生产力水平测算(版本3,2010-2023年)

1、搜数据皮皮侠&#xff0c;编号14172、使用兑换码0447220m6ZHB006826sU14Vv数据来源《中国统计年鉴》、《中国能源统计年鉴》、《中国工业统计年鉴》、《中国环境统计年鉴》、能源统计局、省级统计年鉴。时间跨度2010-2023年区域跨度全国31个省市自治区&#xff08;不含港澳台…...

RWA抵押:稳定币的“硬锚革命”如何撬动十万亿级金融新基建?

——波士顿咨询预言&#xff1a;当国债、房产上链&#xff0c;加密货币将迎来“信用时代”引言&#xff1a;稳定币的“信任危机”与RWA的破局之道2022年&#xff0c;LUNA/UST崩盘事件让全球加密市场陷入恐慌&#xff0c;算法稳定币的“无锚风险”暴露无遗。这场危机揭示了一个核…...