تیسیال
محتویات |
تاریخچه [ویرایش]
زبان Tcl (مخفف Tool Command Language - زبان کنترل ابزار) حاصل تحقیقات John Ousterhout روی ابزارهای رایانه ای طراحی مدارهای الکتریکی در دانشگاه برکلی است. در این تحقیقات، Ousterhout و دانشجویانش مجبور بودند برای هریک از این ابزارها یک زبان کنترل جداگانه طراحی کنند، اما به دلیل توجه بیشتر به خود ابزار (و نه زبان)، ابزارها عموما دارای زبانهای کنترل ضعیفی بودند. در پاییز سال ۱۹۸۷، در آزمایشگاه شرکت DEC، این ایده به ذهن Ousterhout رسید که یک زبان فرمان قابل جاسازی(Emdeddable Command Language) طراحی کند. یک زبان مفسری (Interpreted) خوب که بتواند به عنوان یک بسته کتابخانهای در برنامه های گوناگون استفاده شود. هدف این بود که مفسر زبان مجموعهای از امکانات اولیه را (مانند متغیرها و ساختارهای کنترلی) فراهم آورد و هر یک از ابزارهای استفاده کننده از آن بتوانند ویژگیهای مورد نظر خود را به آن اضافه کنند. Ousterhout در سال ۱۹۸۸ پس از بازگشت از آزمایشگاه DEC، کار بر روی Tcl را شروع کرد و نخستین نسخه آن را در یک متن پرداز (Text Editor) گرافیکی به کار گرفت. در ابتدا این کار فقط جنبه تحقیقاتی داشت و Ousterhout گمان نمیکرد دیگران هم به استقاده از آن علاقه مند باشند.
فلسفه زبان[۱] [ویرایش]
نیاز به امکان جاسازی (Embeddability) قابلیت ویژه زبان Tcl است و به گفته Ousterhout باعث میشود که اهداف زیر برای زبان در نظر گرفته شود:
۱.زبان باید گسترش پذیر(extensible) باشد: افزودن امکانات جدید به زبان توسط سایر افراد باید به آسانی امکان پذیر باشد و امکانات اضافه شده باید چنان باشند که انگار جزئی از خود زبان هستند(طبیعی باشند، نه این که با استفاده از اعمال پیچیدهای به مقصود برسند).
۲.زبان باید ساده و عمومی باشد، تا بتواند به آسانی با برنامههای گوناگون کار کند و امکاناتی را که این برنامهها میتوانند به زبان اضافه کنند محدود نکند.
۳.زبان باید امکانات خوبی برای ادغام داشته باشد، زیرا امکانات مهمتر زبان آنهایی است که توسط برنامه استفاده کننده به زبان افزوده شده است و کار اصلی زبان ادغام (integration) و پیوند دادن آنها با یکدیگر است.
نوآوری ها[۱] [ویرایش]
مهمترین نوآوریهای Tcl عبارتند از قابلیت جاسازی و آسانی تولید واسط کاربر گرافیکی. با ایجاد قابلیت جاسازی، مشکل بسیاری از افرادی که نیاز به یک زبان دارند، اما نمیخواهند یک زبان کامل را از ابتدا طراحی کنند حل شده است. به دلیل آسانی جاسازی Tcl در سایر برنامه ها، استفاده از آن در اوایل دهه ۹۰ به سرعت رشد کرد. قابلیت دیگر Tcl، مجموعه ابزار Tk است که به عنوان گسترشی بر Tcl تولید شد و امکان ایجاد واسط کاربر گرافیکی با استفاده از ادغام مؤلفه(component)ها را به وسیله Tcl فراهم آورد. این قابلیت نیز به امکان استفاده از Tcl برای تولید برنامههای بزرگتر و با واسط کاربر مناسب افزود و در کسترش استفاده از آن سهم به سزایی داشت.
کاربردها [ویرایش]
برخی از کاربردهای Tcl به شرح زیر است[۱]:
- کاربردهای وب : از آنجا که Tcl یک زبان رشته-محور است برای برنامههای وبی مفید است. از نمونه برنامههای وبی استفاده کننده از Tcl میتوان به AOLserver و TclHttpd اشاره کرد. به علاوه کتابخانههای CGI برای Tcl موجود است که امکان استفاده از آن به عنوان یک زبان برنامه نویسی وب را فراهم میکند.
- برنامههای با واسط کاربر گرافیکی (GUI Desktop Applications): ابزار Tk برای ایجاد برنامههای گرافیکی بسیار قدرتمند است. به علاوه این ابزار چند-سکویی (چندسکویی) است و بر روی [[لینوکس|Windows, [[Linux و Mac OS X قابل استفاده و اجراست.
- آزمایش و خودکارسازی : Tcl خود دارای یک چارچوب تست به نام tcltest است. به علاوه شرکتهایی مانند Oracle, Sybase و Cisco میلیونها خط کد Tcl برای تست محصولات خود دارند.
- پایگاههای داده: Tcl دارای گسترشهایی برای کار با پایگاههای داده گوناگون مانند MySQL, Sybase, PostgreSQL, Oracle و Berkeley DB میباشد. همچنین بستههای wrapper ای وجود دارند که یک واسط واحد برای چند نوع پایگاه داده فراهم میکنند.
- توسعه نهفته (Embedded Development) : استفاده از Tcl به علت قابلیت ادغام بالای آن، هم در محصولات سختافزاری مانند محصولات Cisco و هم در محصولات نرم افزاری مانند نرم افزارهای طراحی به کمک رایانه (CAD) و خودکارسازی طراحی الکترونیکی (EDA) رایج است. ابزار شبیه سازی Modelsim یکی از ابزارهایی است که با زبان Tcl کار میکند.
علاوه بر کابردهای فوق، کاربردهای دیگر تحقیقاتی از Tcl نیز مشاهده شده است. به عنوان مثال در سیستمهای رباتیک از زبان Tcl استفاده شده است[4]. همچنین این زبان در توسعه سریع نرم افزار (Rapid Application Development) نیز استفاده شده است[۵].
بررسی زبان شناختی(ساختار و نحو زبان) [ویرایش]
برنامههای Tcl تشکیل شده اند از دستورهایی که با semicolon یا با رفتن به خط جدید (newline) از هم جدا شده اند. هر دستور از تعدادی کلمه تشکیل شده است که با فاصله از هم جدا شده اند. همهٔ دستورات Tcl مقدار برمیگردانند. اگر برگرداندن مقدار برای دستوری معنا نداشته باشد، یک رشته ی تهی برمیگرداند.
متغیرها [ویرایش]
در Tcl نیازی به تعریف متغیر نیست. هر متغیری در اولین دفعه استفاده آن، تعریف میشود. همچنین متغیرها در Tcl دارای نوع نیستند. هر متغیری میتواند هر مقداری بگیرد[۱]. البته میتوان با استفاده از دستور variable اقدام به تعریف متغیر در یک فضای نام (علوم رایانه) کرد[۳]. با استفاده از دستور set میتوان مقادیر را در متغیرها ذخیره و از آنها بازیابی نمود. برای ذخیره :
set x ۳۲ </souce> برای خواندن مقدار : <source lang="tcl"> set x
برای استفاده از مقادیر یک متغیر از روش «جایگذاری متغیر» به شکل زیر استفاده میشود:
expr $x+۳
این دستور مقدار x+۳ را برمیگرداند. هنگامی که یک علامت دلار در عبارت ظاهر میشود، Tcl حروف و اعداد پس از آن را به عنوان نام متغیر تعبیر میکند و مقدار آن متغیر را به جای نام آن میگذارد[۱].
جایگذاری متغیر را میتوان برای همه کلمههای یک دستور Tcl، مستقل از این که آن کلمه یک نام دستور و یا یک آرگومان است، به کار برد. مثلا عبارات زیر معادل عبارات قبلی است :
set a expr set x ۳۲ $a $x+۳
ساختارهای کنترلی [ویرایش]
Tcl مجموعه کاملی از دستورات کنترلی شامل دستورات اجرای شرطی، دستورات حلقه و دستورات زیربرنامه ای را دارد. دستورهای کنترلی Tcl دستوراتی عادی هستند که به عنوان آرگومان، اسکریپتهای Tcl میگیرند[۱].به عنوان مثال دستور proc که برای تعریف زیربرنامه به کار میرود، سه آرگومان میگیرد : نام زیربرنامه، لیست نام پارامترهای آن، و بدنه زیربرنامه که یک اسکریپت Tcl است:
proc power {base p} { set result 1 while {$p> ۰} { set result [expr $result * $base] set p [expr $p - ۱] } return $result }
مشابها دستور while که در بالا مشاهده میشود، یک دستور Tcl است که دو آرگومان میگیرد : یک عبارت که همان عبارت شرط است و یک بدنه که یک اسکریپت Tcl است.
از این زیربرنامه میتوان به شکل زیر استفاده کرد :
power 2 6 power ۱٫۱۵ ۵
دستورها و عبارتها [ویرایش]
همهی امکانات اساسی Tcl به وسیله دستورها نمایش داده میشوند.حتی عبارات نیز به وسیله اجرای دستورات و به عنوان خروجی آنها محاسبه میشوند. قالب معمول دستورهای Tcl به شکل زیر است [۲] :
command arg1 arg2 arg۳ …...
دستورهای Tcl به سه دسته تقسیم میشوند [۱]:
۱.دستورهای توکار (built-in commands) : این دستورهای به وسیله مفسر Tcl فراهم میشوند و در همه برنامههای Tcl قابل استفاده اند. دستورهای proc,while,set و return که در مثالهای بالا آمده اند نمونه هایی از این دستورات هستند.
۲.دستورهایی که به وسیله امکان گسترش (Extension mechanism) زبانTcl به آن اضافه میشوند. میتوان به وسیله توابعی که کتابخانه Tcl فراهم میکند، نام یک دستور و زیربرنامه اجرا کننده ی آن (به زبان C و ++C) را به مفسر Tcl اطلاع داد. پس از این کار هر کجا که آن نام در اسکریپت Tcl ظاهر شود، مفسر همان تابع معرفی شده (به زبان C) را برای اجرای دستور فراخوانی میکند. دستورات توکار Tcl نیز به همین روش پیاده سازی شده اند.
۳.زیربرنامههای تعریف شده به وسیله دستور proc: به طور کلی از extension برای پیاده سازی دستورهای سطح پایین و از proc برای پیادهسازی دستورهای سطح بالا که نوشتن آنها به Tcl آسانتر است استفاده میشود.
چنانکه گفته شد عبارات در Tcl به وسیله اجرای دستور ارزیابی میشوند. به عبارت دیگر مفسر Tcl خود عبارات را ارزیابی نمیکند، بلکه تنها عمل دسته بندی آرگومانها، جایگذاری مقادیر و فراخوانی دستور را انجام میدهد. به همین دلیل در Tcl از دستور expr برای ارزیابی عبارات ریاضی استفاده میشود[۲].
دستور expr با آرگومانهای خود به شکل عبارت ریاضی برخورد میکند[۱].این دستور با عبارات ریاضی، شامل اعداد صحیح، اعشاری و مقادیر منطقی (boolean) سر و کار دارد. قواعد حاکم بر عبارات expr همان است که بر عبارات در زبانC حاکم است[۲]. به علاوه دستور expr برخی توابع اولیه ریاضی را نیز پشتیبانی میکند. به عنوان مثال [۲] :
set len [expr [string length foobar ] ]
که مقدار طول رشته foobar را (که برابر با۶ است) محاسبه میکند و :
set pi [expr {۲*asin(۱٫۰)}]
که مقدار عدد pi را محاسبه میکند.
زبان Tcl مقادیر درون علامت نقل قول ( ” ” ) را ارزیابی و به جای عبارات درون آن مقادیر لازم را قرار میدهد. به قراردادن یک عبارت در آکولاد ( { } ) میتوان از این کار جلوگیری کرد :
set name Ali ”My name is $name” {“My name is $name”}
دستور دوم مقدار My name is Ali را برمیگرداند در حالی که دستور سوم مقدار My name is $name را برمیگرداند.
رشته ها[۲] [ویرایش]
رشتهها واحد اساسی داده در Tcl هستند و به همین دلیل است که دستورات زیادی برای کار با آنها وجود دارد.
دستور string مجموعه ای است از عملیات قابل انجام بر روی رشتهها. نمونه ای از این عمل را در مثال بالا در بحث عبارتها مشاهده میکنیم. اولین آرگومان این دستور نام عملی است که باید انجام گیرد. برخی از اعمال مجاز عبارتند از :
bytelength, compare, equal, first, index, is, last, length, map, match, range, repeat, replace, tolower, totitle, toupper, trim, trimleft, trimright, wordend, wordstart
Tcl امکاناتی را برای کار با اندیسها در رشتهها فراهم میکند. کاراکترها در رشته از ۰ شمرده میشوند. به عنوان مثال دستور زیر کاراکترهای سوم تا آخر رشته با نام name را برمیگرداند. مثلا اگر name حاوی مقدار ahmadi باشد:
string range $name 3 end
مقدار adi را برمیگرداند.
برخی از اندیسهای قابل استفاده در این دستورات عبارتند از:
first, last, wordstart, wordend
همچنین دستور string امکاناتی را برای بررسی تطابق یک رشته با یک رشته دیگر و نیز تعلق یک رشته به یک کلاس خاص (مثلا عدد بودن محتویات یک رشته) فراهم میکند.
Tcl همچنین دستوراتی مانند append, scan, format, binary را برای عملیات پیشرفته روی رشتهها فراهم میکند.
توضیحات (Comments) [ویرایش]
در زبان Tcl از علامت # برای مشخص کردن توضیحات برنامه استفاده میشود. هر توضیح یک خط را اشغال میکند. برای توضیحات چند خطی میتوان از قراردادن \ در پایان هر یک از خطوط استفاده کرد[۲]. در زیر مثالهایی از توضیحات Tcl مشاهده میشود.
# This is a simpel line of comment #This is a line of comment \ and here is the rest of the line above
لیستها [ویرایش]
یکی از قابلیتها در زبان Tcl، امکان کار با لیستهاست. برخی از دستورهای کار با لیستها عبارتند از[۲] :
list, lindex, llength, lrange, lappend, linsert, lsearch, lreplace, …
لیستها در Tcl دارای دو کاربرد عمده هستند [۳]:
۱.استفاده در دستور کنترلی foreach
2.ساخت پویای اجزای یک دستور Tcl برای اجرای آن در آینده به وسیله دستور eval
البته لیستها وسیله مناسبی برای ساخت دادهساختارهای پیچیده در Tcl نیستند و برای چنین کاری استفاده از آرایهها مناسبتر است [۲]. یک نمونه از کاربرد دستورهای لیست در Tcl در زیر آمده است[۳]:
٪ set c۱ {Bob Carol} Bob Carol ٪ set c۲ [list Ted Alice] Ted Alice ٪ set Party۱ [list $c۱ $c۲] {Bob Carol} {Ted Alice} ٪ set Party۲ [concat $c۱ $c۲] Bob Carol Ted Alice ٪ linsert $Party1 1 Richard {Bob Carol} Richard {Ted Alice} ٪
آرایهها [ویرایش]
آرایه یک متغیر Tcl با اندیسهای رشته ای است. میتوان به اندیس به چشم کلید و به آرایه به دید مجموعه ای از عناصر که به وسیله کیلد قابل شناسایی هستند نگریست[۲]. از این نظر، میتوان گفت آرایههای Tcl مانند Hashها در زبان Perl هستند [۳]. قابلیت انعطاف آرایهها آنها را به ابزاری مهم برای برنامه نویسی در Tcl تبدیل میکند. یکی از استفادههای مهم آرایهها در Tcl ایجاد دادهساختارهای پیچیده است که در زبانهایی مثل C و Pascal به وسیله مفاهیمی مانند struct و record تعریف میشوند[۲].
در زیر نمونهای از کاربرد آرایهها در Tcl دیده میشود[۳]:
٪ set People(friend) Tom Tom ٪ set People(spouse) Marcia Marcia ٪ set People(boss) Jack Jack ٪ array names People friend boss spouse ٪ set Person $People(friend) Tom ٪ array get People friend Tom boss Jack spouse Marcia ٪ set People(friend) \ [concat $People(friend) Bob] Tom Bob ٪ set Person $People(friend) Tom Bob ٪
زیربرنامهها و محدودهها [ویرایش]
چنانکه گفته شد زیربرنامهها امکان کپسولهسازی (encapsulation) دستورات در قالب یک دستور را فراهم میکنند. زیربرنامهها همچنین یک محدوده(scope) محلی برای متغیرها ایجاد میکنند[۲].
در آغاز، Tcl دارای یک محدوده سراسری (global) برای متغیرها، محدودههای محلی درون زیربرنامهها و یک محدوده سراسری برای زیربرنامهها بود. از Tcl ۸٫۰ به بعد محدوده-نامها به Tcl اضافه شد که محدوده جدیدی برای زیربرنامهها و متغیرهای سراسری به وجود میآورد.نکته دیگر آنکه زیربرنامهها و متغیرها دارای محدوده-نامهای جدا هستند بنابراین میتوان بدون ایجاد مشکل، متغیر و زیربرنامه همنام داشت[۲]. متغیرهای تعریف شده در هر زیربرنامه، تنها در همان زیربرنامه قابل دسترسی و استقاده هستند. به علاوه متغیرهای سراسری در حالت عادی در برنامهها قابل استفاده نیستند و برای استفاده از آنها باید به شکل صریح (explicit) و با استفاده از دستور global آنها را به سیستم معرفی کرد. همچنین متغیرهای تعریف شده در بلوکهای بالاتر نیز به حالت عادی در بلوک درونیتر قابل استفاده نیستند و باید به وسیله دستور upvar آنها را به سیستم معرفی کرد[۳].
نمونههایی دیگر از تعریف زیربرنامهها، به همراه شیوه استفاده از دستور upvar در زیر آمده است[۲]:
proc RandomInit { seed } { global randomSeed set randomSeed $seed } proc Random {} { global randomSeed set randomSeed [expr ($randomSeed*۹۳۰۱ + ۴۹۲۹۷) ٪ ۲۳۳۲۸۰] return [expr $randomSeed/double(۲۳۳۲۸۰)] } proc RandomRange { range } { expr int([Random]*$range) }
که حاصل اجرای آن به این صورت است :
RandomInit [pid] => ۵۰۴۹ Random => ۰٫۵۱۷۶۸۶۸۹۹۸۶۳ Random => ۰٫۲۱۷۱۷۶۷۸۳۲۶۵ RandomRange ۱۰۰ => ۱۷
به عنوان نمونهای از استقاده از دستور upvar میتوان به پیادهسازی پشته با استفاده از لیست اشاره کرد[۲]:
proc Push { stack value } { upvar $stack list lappend list $value } proc Pop { stack } { upvar $stack list set value [lindex $list end] set list [lrange $list ۰ [expr [llength $list]-۲]] return $value }
که در آن stack$ حاوی نام متغیر لیست دارای اطلاعات stack است که در بیرون از محدوده زیربرنامه قرار دارد و به عنوان پارامتر به برنامه فرستاده و تبدیل به یک متغیر قابل استفاده در زیربرنامه شده است.
سایر امکانات[۲] [ویرایش]
از جمله سایر امکاناتی که زبان Tcl فراهم میکند میتوان به موارد زیر اشاره کرد:
- عبارات منظم (Regular Expressions)
- کتابخانهها و بستههای(Packages) اسکریپتی
- انعکاس (Reflection) و اشکالزدایی
- محدوده-نامها (Namespaces)
- ترجمه (Internationalization)
- برنامه سازی رویداد-محور(Event-driven Programming)
- برنامهسازی با سوکت ها
- برای اطلاع بیشتر در این موارد میتوان به [۲] مراجعه کرد.
نمونه برنامههای کامل Tcl [ویرایش]
در زیر نمونههایی از برنامههای کامل Tcl آورده شده است. نمونه اول یک اسکریپت کنترلی برای برنامه شبیهسازی Modelsim است و دستورهای افزوده شده به Tcl توسط برنامه Modelsim در آن به خوبی مشهود است:
# Copy Test Bench Files to the appropriate place # $testAddr is the address of the simulation files # $benchAddr is the address of the test bench directory set benchRoot $۱ set testRoot $۲ set testsAddr $۳ set benchName $۴ set testName $۵ # The address in which results should be put set destAddr $benchRoot #Copy test bench specified on command line file delete -force $testRoot/tsource file copy -force $benchRoot/$benchName $testRoot/tsource # Run the simulation vsim -voptargs=+acc work.tbleon # Add the processor's pinout signals add wave sim:/tbleon/tb/p۰/leon۰/resetn add wave sim:/tbleon/tb/p۰/leon۰/clk add wave sim:/tbleon/tb/p۰/leon۰/pllref add wave sim:/tbleon/tb/p۰/leon۰/plllock add wave sim:/tbleon/tb/p۰/leon۰/errorn add wave sim:/tbleon/tb/p۰/leon۰/address add wave sim:/tbleon/tb/p۰/leon۰/data add wave sim:/tbleon/tb/p۰/leon۰/ramsn add wave sim:/tbleon/tb/p۰/leon۰/ramoen add wave sim:/tbleon/tb/p۰/leon۰/rwen add wave sim:/tbleon/tb/p۰/leon۰/romsn add wave sim:/tbleon/tb/p۰/leon۰/iosn add wave sim:/tbleon/tb/p۰/leon۰/oen add wave sim:/tbleon/tb/p۰/leon۰/read add wave sim:/tbleon/tb/p۰/leon۰/writen add wave sim:/tbleon/tb/p۰/leon۰/brdyn add wave sim:/tbleon/tb/p۰/leon۰/bexcn add wave sim:/tbleon/tb/p۰/leon۰/sdcke add wave sim:/tbleon/tb/p۰/leon۰/sdcsn add wave sim:/tbleon/tb/p۰/leon۰/sdwen add wave sim:/tbleon/tb/p۰/leon۰/sdrasn add wave sim:/tbleon/tb/p۰/leon۰/sdcasn add wave sim:/tbleon/tb/p۰/leon۰/sddqm add wave sim:/tbleon/tb/p۰/leon۰/sdclk add wave sim:/tbleon/tb/p۰/leon۰/sa add wave sim:/tbleon/tb/p۰/leon۰/sd add wave sim:/tbleon/tb/p۰/leon۰/pio add wave sim:/tbleon/tb/p۰/leon۰/wdogn add wave sim:/tbleon/tb/p۰/leon۰/dsuen add wave sim:/tbleon/tb/p۰/leon۰/dsutx add wave sim:/tbleon/tb/p۰/leon۰/dsurx add wave sim:/tbleon/tb/p۰/leon۰/dsubre add wave sim:/tbleon/tb/p۰/leon۰/dsuact add wave sim:/tbleon/tb/p۰/leon۰/test # To continue script execution onbreak { resume } # First run run -all # Set onbreak to its default value onbreak "" # Open dataset as gold for comparison dataset open $benchRoot/$benchName/gold.wlf echo Golden Version Opened for comparison! # Starting Compare compare start gold sim # Add signals for comparison compare add gold:/tbleon/tb/p۰/leon۰/resetn compare add gold:/tbleon/tb/p۰/leon۰/clk compare add gold:/tbleon/tb/p۰/leon۰/pllref compare add gold:/tbleon/tb/p۰/leon۰/plllock compare add gold:/tbleon/tb/p۰/leon۰/errorn compare add gold:/tbleon/tb/p۰/leon۰/address compare add gold:/tbleon/tb/p۰/leon۰/data compare add gold:/tbleon/tb/p۰/leon۰/ramsn compare add gold:/tbleon/tb/p۰/leon۰/ramoen compare add gold:/tbleon/tb/p۰/leon۰/rwen compare add gold:/tbleon/tb/p۰/leon۰/romsn compare add gold:/tbleon/tb/p۰/leon۰/iosn compare add gold:/tbleon/tb/p۰/leon۰/oen compare add gold:/tbleon/tb/p۰/leon۰/read compare add gold:/tbleon/tb/p۰/leon۰/writen compare add gold:/tbleon/tb/p۰/leon۰/brdyn compare add gold:/tbleon/tb/p۰/leon۰/bexcn compare add gold:/tbleon/tb/p۰/leon۰/sdcke compare add gold:/tbleon/tb/p۰/leon۰/sdcsn compare add gold:/tbleon/tb/p۰/leon۰/sdwen compare add gold:/tbleon/tb/p۰/leon۰/sdrasn compare add gold:/tbleon/tb/p۰/leon۰/sdcasn compare add gold:/tbleon/tb/p۰/leon۰/sddqm compare add gold:/tbleon/tb/p۰/leon۰/sdclk compare add gold:/tbleon/tb/p۰/leon۰/sa compare add gold:/tbleon/tb/p۰/leon۰/sd compare add gold:/tbleon/tb/p۰/leon۰/pio compare add gold:/tbleon/tb/p۰/leon۰/wdogn compare add gold:/tbleon/tb/p۰/leon۰/dsuen compare add gold:/tbleon/tb/p۰/leon۰/dsutx compare add gold:/tbleon/tb/p۰/leon۰/dsurx compare add gold:/tbleon/tb/p۰/leon۰/dsubre compare add gold:/tbleon/tb/p۰/leon۰/dsuact compare add gold:/tbleon/tb/p۰/leon۰/test #compare add -r gold:/* # Running compare compare run # Saving comparison and differences compare saverules $destAddr/$testName-$benchName-comprules.sav onerror { echo Hurray! No Differences Found!!; resume } compare savediffs $destAddr/$testName-$benchName-compdiffs.sav echo Comparison complete! #Goodbye! quit -sim; dataset close gold
نمونه دوم یک برنامه ping ساده است که در محیط لینوکس اجرا میشود[۶]:
#!/usr/local/bin/wish -f # Ping example #۱ frame .buttons -borderwidth 10 pack .buttons -side top -fill x button .buttons.quit -text Quit -command exit button .buttons.ping -text Ping -command Ping pack .buttons.quit .buttons.ping -side right frame .f ; pack .f -side top label .f.l -text Host: entry .f.host -width ۲۰ -relief sunken pack .f.l .f.host -side left text .log -width ۶۰ -height ۱۰ -bd ۲ -relief raised pack .log -side top proc Ping {} { set hostname [.f.host get] catch {exec /usr/sbin/ping $hostname} result .log insert end $result .log insert end \n }
به عنوان نمونهای دیگر میتوان برنامه تبدیل فایلهای Dos به Unix را مشاهده کرد[۱]:
#!/usr/local/bin/tclsh # Dos2Unix # Convert a file to Unix-style line endings # If the file is a directory, then recursively # convert all the files in the directory and below. ## Arguments # f The name of a file or directory. ## Side Effects: # Rewrites the file to have LF line-endings proc Dos2Unix {f} { puts $f if {[file isdirectory $f]} { foreach g [glob [file join $f *]] { Dos2Unix $g } } else { set in [open $f] set out [open $f.new w] fconfigure $out -translation lf puts -nonewline $out [read $in] close $out close $in file rename -force $f.new $f } } # Process each command-line argument foreach f $argv { Dos2Unix $f }
منابع [ویرایش]
[۱] ----, About Tcl, http://www.tcl.tk/about, AT=۷ June ۲۰۰۹
[۲] Brent Welch, Practical Programming in Tcl and Tk (۳rd Edition) , PrenticeHall, ۱۹۹۹
[۳] Brian Bilbrey, Tcl/Tk quick start, IBM developerWorks, http://www.ibm.com/developerworks/edu/l-dw-linuxtcl-i.html, ۲۰۰۱
[۴] A.C.Leite, F.C.Lizarralde, Application of Tcl/Tk for a robotic system, 13th Annual Tcl/Tk conference, October ۲۰۰۶
[۵] Rapid Application Development Using the Tcl/Tk Language, IEEE, 1996, accelconf.web.cern.ch/AccelConf/p۹۵/ARTICLES /MPR/MPR02.pdf
[۶] Yifan Tang, Scripts and Utilities (Tcl/Tk lecture, Course : cs300) , University of Tennessee, Department of Computer Science,Fall ۲۰۰۲
|
|||||||||||
|
|||||||||||||||||||||||||||||||||||||||||