5.3 Categorization

5.3.1 CATEGORIES

When a package is created, it is put under /usr/ports/packages/All and links are made from one or more subdirectories of /usr/ports/packages. The names of these subdirectories are specified by the variable CATEGORIES. It is intended to make life easier for the user when he is wading through the pile of packages on the FTP site or the CDROM. Please take a look at the current list of categories and pick the ones that are suitable for your port.

This list also determines where in the ports tree the port is imported. If you put more than one category here, it is assumed that the port files will be put in the subdirectory with the name in the first category. See below for more discussion about how to pick the right categories.

5.3.2 Current list of categories

Here is the current list of port categories. Those marked with an asterisk (*) are virtual categories——those that do not have a corresponding subdirectory in the ports tree. They are only used as secondary categories, and only for search purposes.

Note: For non-virtual categories, you will find a one-line description in the COMMENT in that subdirectory's Makefile.

Category Description Notes
accessibility Ports to help disabled users.  
afterstep* Ports to support the AfterStep window manager.  
arabic Arabic language support.  
archivers Archiving tools.  
astro Astronomical ports.  
audio Sound support.  
benchmarks Benchmarking utilities.  
biology Biology-related software.  
cad Computer aided design tools.  
chinese Chinese language support.  
comms Communication software. Mostly software to talk to your serial port.
converters Character code converters.  
databases Databases.  
deskutils Things that used to be on the desktop before computers were invented.  
devel Development utilities. Do not put libraries here just because they are libraries——unless they truly do not belong anywhere else, they should not be in this category.
dns DNS-related software.  
editors General editors. Specialized editors go in the section for those tools (e.g., a mathematical-formula editor will go in math).
elisp* Emacs-lisp ports.  
emulators Emulators for other operating systems. Terminal emulators do not belong here——X-based ones should go to x11 and text-based ones to either comms or misc, depending on the exact functionality.
finance Monetary, financial and related applications.  
french French language support.  
ftp FTP client and server utilities. If your port speaks both FTP and HTTP, put it in ftp with a secondary category of www.
games 遊戲。  
geography* 地理圖資相關的軟體。  
german 德文相關支援。  
gnome* Ports from the GNOME Project.  
gnustep* GNUstep 桌面環境相關的軟體。  
graphics 圖形處理的工具軟體。  
hamradio* Software for amateur radio.  
haskell* Software related to the Haskell language.  
hebrew Hebrew language support.  
hungarian Hungarian language support.  
ipv6* IPv6 related software.  
irc Internet Relay Chat utilities.  
japanese Japanese language support.  
java Software related to the Java language. The java category shall not be the only one for a port. Save for ports directly related to the Java language, porters are also encouraged not to use java as the main category of a port.
kde* Ports from the K Desktop Environment (KDE) Project.  
kld* Kernel loadable modules。  
korean Korean language support.  
lang Programming languages.  
linux* Linux applications and support utilities.  
lisp* Software related to the Lisp language.  
mail Mail software.  
math Numerical computation software and other utilities for mathematics.  
mbone MBone applications.  
misc Miscellaneous utilities Basically things that do not belong anywhere else. If at all possible, try to find a better category for your port than misc, as ports tend to get overlooked in here.
multimedia Multimedia software.  
net Miscellaneous networking software.  
net-im Instant messaging software.  
net-mgmt Networking management software.  
net-p2p Peer to peer network applications.  
news USENET news software.  
palm Software support for the Palm™ series.  
parallel* Applications dealing with parallelism in computing.  
pear* Ports related to the Pear PHP framework.  
perl5* Ports that require Perl version 5 to run.  
plan9* Various programs from Plan9.  
polish Polish language support.  
ports-mgmt FreeBSD ports 及 packages 的管理、安裝、開發。  
portuguese Portuguese language support.  
print Printing software. Desktop publishing tools (previewers, etc.) belong here too.
python* Software related to the Python language.  
ruby* Software related to the Ruby language.  
rubygems* Ports of RubyGems packages.  
russian Russian language support.  
scheme* Software related to the Scheme language.  
science Scientific ports that do not fit into other categories such as astro, biology and math.  
security Security utilities.  
shells Command line shells.  
spanish* 西班牙文的相關支援。  
sysutils System utilities.  
tcl* 使用 Tcl 語言的軟體。  
textproc Text processing utilities. It does not include desktop publishing tools, which go to print.
tk* 使用 Tk 語言的程式。  
ukrainian Ukrainian language support.  
vietnamese Vietnamese language support.  
windowmaker* Ports to support the WindowMaker window manager.  
www Software related to the World Wide Web. HTML language support belongs here too.
x11 The X Window System and friends. This category is only for software that directly supports the window system. Do not put regular X applications here; most of them should go into other x11-* categories (see below). If your port is an X application, define USE_XLIB (implied by USE_IMAKE) and put it in the appropriate category.
x11-clocks X11 clocks.  
x11-drivers X11 驅動程式。  
x11-fm X11 file managers.  
x11-fonts X11 fonts and font utilities.  
x11-servers X11 servers.  
x11-themes X11 themes.  
x11-toolkits X11 toolkits.  
x11-wm X11 window managers.  
xfce* Xfce 桌面環境的相關軟體。  
zope* Zope support.  

5.3.3 Choosing the right category

As many of the categories overlap, you often have to choose which of the categories should be the primary category of your port. There are several rules that govern this issue. Here is the list of priorities, in decreasing order of precedence:

If you are not sure about the category, please put a comment to that effect in your send-pr(1) submission so we can discuss it before we import it. If you are a committer, send a note to the FreeBSD ports 郵遞論壇 so we can discuss it first. Too often, new ports are imported to the wrong category only to be moved right away. This causes unnecessary and undesirable bloat in the master source repository.

5.3.4 Proposing a new category

As the Ports Collection has grown over time, various new categories have been introduced. New categories can either be virtual categories——those that do not have a corresponding subdirectory in the ports tree—— or physical categories——those that do. The following text discusses the issues involved in creating a new physical category so that you can understand them before you propose one.

Our existing practice has been to avoid creating a new physical category unless either a large number of ports would logically belong to it, or the ports that would belong to it are a logically distinct group that is of limited general interest (for instance, categories related to spoken human languages), or preferably both.

The rationale for this is that such a change creates a fair amount of work for both the committers and also for all users who track changes to the Ports Collection. In addition, proposed category changes just naturally seem to attract controversy. (Perhaps this is because there is no clear consensus on when a category is ``too big'', nor whether categories should lend themselves to browsing (and thus what number of categories would be an ideal number), and so forth.)

Here is the procedure:

  1. Propose the new category on FreeBSD ports 郵遞論壇. You should include a detailed rationale for the new category, including why you feel the existing categories are not sufficient, and the list of existing ports proposed to move. (If there are new ports pending in GNATS that would fit this category, list them too.) If you are the maintainer and/or submitter, respectively, mention that as it may help you to make your case.

  2. Participate in the discussion.

  3. If it seems that there is support for your idea, file a PR which includes both the rationale and the list of existing ports that need to be moved. Ideally, this PR should also include patches for the following:

    • Makefiles for the new ports once they are repocopied

    • Makefile for the new category

    • Makefile for the old ports' categories

    • Makefiles for ports that depend on the old ports

    • (for extra credit, you can include the other files that have to change, as per the procedure in the Committer's Guide.)

  4. Since it affects the ports infrastructure and involves not only performing repo-copies but also possibly running regression tests on the build cluster, the PR should be assigned to the Ports Management Team .

  5. If that PR is approved, a committer will need to follow the rest of the procedure that is outlined in the Committer's Guide.

Proposing a new virtual category should be similar to the above but much less involved, since no ports will actually have to move. In this case, the only patches to include in the PR would be those to add the new category to the CATEGORIES of the affected ports.

5.3.5 Proposing reorganizing all the categories

Occasionally someone proposes reorganizing the categories with either a 2-level structure, or some other kind of keyword structure. To date, nothing has come of any of these proposals because, while they are very easy to make, the effort involved to retrofit the entire existing ports collection with any kind of reorganization is daunting to say the very least. Please read the history of these proposals in the mailing list archives before you post this idea; furthermore, you should be prepared to be challenged to offer a working prototype.

For questions about the FreeBSD ports system, e-mail <ports@FreeBSD.org>.
For questions about this documentation, e-mail <doc@FreeBSD.org>.