[//000000001]: # (fileutil::magic::cfront \- file utilities) [//000000002]: # (Generated from file 'cfront\.man' by tcllib/doctools with format 'markdown') [//000000003]: # (fileutil::magic::cfront\(n\) 1\.2\.0 tcllib "file utilities")
[ Main Table Of Contents | Table Of Contents | Keyword Index | Categories | Modules | Applications ]
# NAME fileutil::magic::cfront \- Generator core for compiler of magic\(5\) files # Table Of Contents - [Table Of Contents](#toc) - [Synopsis](#synopsis) - [Description](#section1) - [COMMANDS](#section2) - [Bugs, Ideas, Feedback](#section3) - [See Also](#seealso) - [Keywords](#keywords) - [Category](#category) # SYNOPSIS package require Tcl 8\.5 package require fileutil::magic::cfront ?1\.2\.0? package require fileutil::magic::cgen ?1\.2\.0? package require fileutil::magic::rt ?1\.2\.0? package require struct::list package require fileutil [__::fileutil::magic::cfront::compile__ *path*\.\.\.](#1) [__::fileutil::magic::cfront::procdef__ *procname* *path*\.\.\.](#2) [__::fileutil::magic::cfront::install__ *path*\.\.\.](#3) # DESCRIPTION This package provides the frontend of a compiler of magic\(5\) files into recognizers based on the __[fileutil::magic::rt](rtcore\.md)__ recognizer runtime package\. For the generator backed used by this compiler see the package __[fileutil::magic::cgen](cgen\.md)__\. # COMMANDS - __::fileutil::magic::cfront::compile__ *path*\.\.\. This command takes the paths of one or more files and directories and compiles all the files, and the files in all the directories into a single analyzer for all the file types specified in these files\. It returns a list whose first item is a list per\-file dictionaries of analyzer scripts and whose second item is a list of analyzer commands\. All the files have to be in the format specified by magic\(5\)\. The result of the command is a Tcl script containing the generated recognizer\. - __::fileutil::magic::cfront::procdef__ *procname* *path*\.\.\. This command behaves like __::fileutil::magic::cfront::compile__ with regard to the specified path arguments, then wraps the resulting recognizer script into a procedure named *procname*, puts code setting up the namespace of *procname* in front, and returns the resulting script\. - __::fileutil::magic::cfront::install__ *path*\.\.\. This command uses __::fileutil::magic::cfront::procdef__ to compile each of the paths into a recognizer procedure and installs the result in the current interpreter\. The name of each new procedure is derived from the name of the file/directory used in its creation, with file/directory "FOO" causing the creation of procedure __::fileutil::magic::/FOO::run__\. # Bugs, Ideas, Feedback This document, and the package it describes, will undoubtedly contain bugs and other problems\. Please report such in the category *fileutil :: magic* of the [Tcllib Trackers](http://core\.tcl\.tk/tcllib/reportlist)\. Please also report any ideas for enhancements you may have for either package and/or documentation\. When proposing code changes, please provide *unified diffs*, i\.e the output of __diff \-u__\. Note further that *attachments* are strongly preferred over inlined patches\. Attachments can be made by going to the __Edit__ form of the ticket immediately after its creation, and then using the left\-most button in the secondary navigation bar\. # SEE ALSO file\(1\), [fileutil](\.\./fileutil/fileutil\.md), magic\(5\) # KEYWORDS [file recognition](\.\./\.\./\.\./\.\./index\.md\#file\_recognition), [file type](\.\./\.\./\.\./\.\./index\.md\#file\_type), [file utilities](\.\./\.\./\.\./\.\./index\.md\#file\_utilities), [mime](\.\./\.\./\.\./\.\./index\.md\#mime), [type](\.\./\.\./\.\./\.\./index\.md\#type) # CATEGORY Programming tools