日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

sty和cls文档编写指南

發(fā)布時(shí)間:2023/12/16 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sty和cls文档编写指南 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

前言

本文是對LATEX 2ε for class and package writers的翻譯和概括。

可以參考以下鏈接得到原文檔
https://www.jianshu.com/p/12b4a4b3afce?from=singlemessage

也可以參考
https://zhuanlan.zhihu.com/p/19705200

文檔編寫的介紹從第三部分開始,文檔的命令從第四部分開始,參數(shù)的傳遞從第五部分開始。

1.sty和cls文檔簡介

a.可以使用docstrip生成sty和cls文件

b.如果命令可以在其他tex文件中使用,應(yīng)該寫在sty文件中。
如果命令(排版格式)只適合某一文檔,應(yīng)該寫在cls文件中。

2.編寫sty和cls

a.tex命令包含三種格式

tex作者使用的,即一般tex文件包含的命令,
sty和cls作者使用的,如\RequirePackge,
tex內(nèi)部命令,如\@temcnta。
您不可以在tex文件中使用后兩種命令。

b.魯棒性

為了增強(qiáng)文檔魯棒性,使用較為嚴(yán)謹(jǐn)?shù)拿睢?br /> 文件加載命令:

\LoadClass{cls file name} %加載cls文件 \LoadClassWithOptions \RequirePackage{sty file name} %加載所需要的包 \RequirePackageWithOptions \input{file name}

不建議使用最后一種,會(huì)導(dǎo)致多次加載。

命令定義

\newcommand \renewcommand \providecommand \CheckCommand \def

上面四個(gè)差別不大,不建議使用第四種,會(huì)導(dǎo)致意外定義新命令

環(huán)境定義

\newenvironment \renewenvironment\def\foo{...} \def\endfoo{...}

上面兩個(gè)均可,不建議使用第三種

c.便攜性

文檔名盡量不要超過8字符,不包括3個(gè)字符的擴(kuò)展名,
不能和已有的latex標(biāo)準(zhǔn)包重名,
盡量加上首字母前綴,比如XXX thesis.cls

d.重定義document

使用\AtBeginDocument和\AtEndDocument重定義docunment

3.cls和sty結(jié)構(gòu)

一個(gè)完整的cls或者sty文件通常包含以下的結(jié)構(gòu)。

a.文檔介紹

\NeedsTeXFormat{LaTeX2e} \ProvidesPackage{包的名稱}[時(shí)間及其他信息]\NeedsTeXFormat{LaTeX2e} \ProvidesClass{類名稱}[時(shí)間及其他信息]

時(shí)間使用YYYY/MM/DD格式

b.引用cls或者sty文件

\RequirePackage[options]{package}[date] \LoadClass[hoptionsi]{hclass-namei}[hdatei]

當(dāng)載入的文件中options和當(dāng)前文檔相同,使用以下命令:

\LoadClassWithOptions{article} \RequirePackageWithOptions{graphics}

c.定義選項(xiàng)

使用如下命令定義選項(xiàng)

\DeclareOption{option}{code}

如果出現(xiàn)了選項(xiàng),則會(huì)執(zhí)行選項(xiàng)中的代碼。
使用如下代碼,將error變?yōu)閣arning

\DeclareOption*{% \PackageWarning{fred}{Unknown option ‘\CurrentOption’}% }

使用如下命令使定義的選項(xiàng)被文檔調(diào)用執(zhí)行

\ProcessOptions\relax

d.最小文檔

文檔必須包括四個(gè)內(nèi)容:
\normalsize,\textwidth, \textheight,頁數(shù)的規(guī)范
一個(gè)最小文檔如下例:

\NeedsTeXFormat{LaTeX2e} \ProvidesClass{minimal}[1995/10/30 Standard LaTeX minimal class] \renewcommand{\normalsize}{\fontsize{10pt}{12pt}\selectfont} \setlength{\textwidth}{6.5in} \setlength{\textheight}{8in} \pagenumbering{arabic} % needed even though this class will % not show page numbers

信件文檔如下例:(文檔名為neplet.cls)

\NeedsTeXFormat{LaTeX2e} \ProvidesClass{neplet}[1995/04/01 NonExistent Press letter class]\DeclareOption*{\PassOptionsToClass{\CurrentOption}{letter}} \ProcessOptions\relax \LoadClass[a4paper]{letter}\renewcommand{\ps@firstpage}{% \renewcommand{\@oddhead}{letterhead goes here}% \renewcommand{\@oddfoot}{letterfoot goes here}% }

4.文檔命令

\NeedsTeXFormat {format-name} [release-date] %文檔的定義 \ProvidesClass {class-name} [release-info]%表示當(dāng)前文檔提供了XX類的定義 \ProvidesPackage {package-name} [release-info]%表示當(dāng)前文檔提供了XX包的定義 \ProvidesFile {file-name} [release-info]%表示當(dāng)前文檔提供了XX文件的定義\RequirePackage [options-list] {package-name} [release-info] \RequirePackageWithOptions {package-name} [release-info]%引用包 \LoadClass [hoptions-listi] {class-name} [release-info] \LoadClassWithOptions {class-name} [release-info]%引用類\DeclareOption {option-name} {code}%選項(xiàng)定義 \DeclareOption* {code}%對于所有選項(xiàng)都為執(zhí)行

以下命令只在定義option的code中使用

\CurrentOption%引用當(dāng)前選項(xiàng) \OptionNotUsed%當(dāng)前選項(xiàng)加入未使用選項(xiàng)列表\PassOptionsToPackage {options-list} {package-name} \PassOptionsToClass {options-list} {class-name}%意味著如果調(diào)用這個(gè)包,就會(huì)執(zhí)行optionlist中的選項(xiàng)\AtEndOfClass{code} \AtEndOfPackage{code}%代碼將在執(zhí)行完整個(gè)包之后執(zhí)行\(zhòng)AtBeginDocument {code} \AtEndDocument {code}%代碼將在執(zhí)行\(zhòng)begin{document}或者\(yùn)end{docpment}時(shí)執(zhí)行\(zhòng)AtBeginDvi {specials} \ProcessOptions% \ProcessOptions* \\@options% \ExecuteOptions {hoptions-listi}

以上只在code中使用

\IfFileExists {file-name} {true} {false}%定義文件不存在時(shí)如何操作,這個(gè)命令本身不會(huì)加載文件 \InputIfFileExists {file-name} {true} {false}%如果存在,執(zhí)行True中代碼,然后加載文件,否則執(zhí)行faulse\ClassError {class-name} {error-text} {help-text} \PackageError {package-name} {error-text} {help-text}%如果在引入包中出現(xiàn)錯(cuò)誤,將顯示text的內(nèi)容。 %\protect加在命令之前,使得其被打印而不是執(zhí)行,\MessageBreak打印換行,\space打印空格。\ClassWarning {class-name} {warning-text} \PackageWarning {package-name} {warning-text} \ClassWarningNoLine {class-name} {warning-text} \PackageWarningNoLine {package-name} {warning-text} \ClassInfo {class-name} {info-text} \PackageInfo {package-name} {info-text}\DeclareRobustCommand {cmd} [num] [default] {definition} \DeclareRobustCommand* {cmd} [num] [default] {definition}%定義更加魯棒的命令,和renewcommand類似。\CheckCommand {cmd} [num] [default] {definition} \CheckCommand* {cmd} [num] [default] {definition}%定義的同時(shí)會(huì)檢查,如果不同則會(huì)產(chǎn)生warning\paperheight \paperwidth%設(shè)定頁面大小\MakeUppercase {text} \MakeLowercase {text}%大小寫轉(zhuǎn)換\ignorespacesafterend%取消空格\normalsfcodes%恢復(fù)字間距\if@compatibility

可能需要重新定義如下命令

\rm \sf \tt \bf \it \sl \sc \normalsize \@normalsize

需要重新定義如下命令

\tiny \footnotesize \small \large \Large \LARGE \huge \Huge \tenrm \elvrm \twlrm . . . \tenbf \elvbf \twlbf . . . \tensf \elvsf \twlsf . . .

可能需要替換如下命令

\vpt \vipt \viipt . . . \prm, \pbf, \ppounds, \pLaTeX . . .

以下命令被移除

\footheight \@maxsep \@dblmaxsep

5.參數(shù)傳遞

參數(shù)傳遞使得tex寫作是不需要重復(fù)添加相同的信息。(比如頁眉上方的標(biāo)題)。遺憾的是原文中并沒有介紹相關(guān)的內(nèi)容。以下內(nèi)容均來自于下方鏈接。
https://blog.csdn.net/RobertChenGuangzhi/article/details/50461514

在cls文件中,使用以下命令定義參數(shù)
\newcommand{\\@ang-name}{默認(rèn)值}
參數(shù)名通常為\@后跟tex文件中使用的名稱
在cls文件中,使用以下命令關(guān)聯(lián)cls參數(shù)和tex參數(shù)

\newcommand{\tex-cmd}[參數(shù)數(shù)目][默認(rèn)值]{\renewcommand{\\@avg-name1}{#1}\renewcommand{\\@avg-name2}{#2}\renewcommand{\\@avg-name3}{#3} ... }

命令名通常為\加上tex文件中引用的名稱。
在cls文件中使用\@avg-name1...調(diào)用參數(shù)

在tex文件中使用如下代碼獲取參數(shù):
\tex-cmd{參數(shù)1的值}{參數(shù)2的值}{參數(shù)3的值}..

總結(jié)

以上是文檔的大概內(nèi)容,我會(huì)更新一篇報(bào)告的cls文件。

總結(jié)

以上是生活随笔為你收集整理的sty和cls文档编写指南的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。