Difference between revisions of "Directory Structure"
(→ext) |
|||
Line 17: | Line 17: | ||
= cgi-bin = | = cgi-bin = | ||
− | Code libraries that power the site. This directory is the base of the library path--that is <code>use Net::OpenID::Consumer;</code> refers to the code in <code>cgi-bin/Net/OpenID/Consumer.pm</code>. It contains all the custom Perl libraries and functions that the code references including the <code>LJ::*</code> and <code>DW::*</code> libraries | + | Code libraries that power the site. This directory is the base of the library path--that is <code>use Net::OpenID::Consumer;</code> refers to the code in <code>cgi-bin/Net/OpenID/Consumer.pm</code>. It contains all the custom Perl libraries and functions that the code references including the <code>LJ::*</code> and <code>DW::*</code> libraries. |
All subdirectories here map to library names, so <code>DW::Foo</code> goes in <code>cgi-bin/DW/Foo.pm</code> and so forth. | All subdirectories here map to library names, so <code>DW::Foo</code> goes in <code>cgi-bin/DW/Foo.pm</code> and so forth. | ||
+ | |||
+ | Code in <code>*.pl</code> files in this directory are also library files but in an older style that haven't been converted over to use .pm. These are described in [[Legacy .pl Files]]. | ||
+ | |||
== LJ == | == LJ == |
Revision as of 09:57, 4 August 2014
This documents the contents of the $LJHOME development folder as present on all Dreamhacks.
Contents
bin
Backend utilities for maintaining and upgrading the site.
Commonly used programs in this directory include:
Subdirectories are:
dev
maint
misc
upgrading
cgi-bin
Code libraries that power the site. This directory is the base of the library path--that is use Net::OpenID::Consumer;
refers to the code in cgi-bin/Net/OpenID/Consumer.pm
. It contains all the custom Perl libraries and functions that the code references including the LJ::*
and DW::*
libraries.
All subdirectories here map to library names, so DW::Foo
goes in cgi-bin/DW/Foo.pm
and so forth.
Code in *.pl
files in this directory are also library files but in an older style that haven't been converted over to use .pm. These are described in Legacy .pl Files.
LJ
Original LJ modules.
DW
Newer, DW-based modules.
doc
Unedited versions of some configuration files are stored here, plus the DocBook manual.
raw
Docbook formatted source for the old and very much out of date docbook code for the LiveJournal server. LiveJournal's version is visible at http://livejournal.com/doc/server/
but Dreamwidth has not generated a user-visible copy.
etc
Various configuration files specific to the local site, such as config.pl
. These files are not copied to the Mercurial repositories so they can be updated without affecting other running installations.
ext
This directory contains any local repository checkouts--for instance, dw-nonfree, Dreamwidth's non-open source code, goes here. The directory structure in dw-nonfree is parallel to the root directory structure -- that is, it contains folders such as htdocs, cgi-bin, bin, though not all folders are present.
This directory also contains local config files in ext/local/etc, so they won't be affected by source code updates.
htdocs
User-facing BML pages, with the directory structure used on the main website. That is to say, anything that appears at http://www.dreamwidth.org/filename.bml
will be here, as htdocs/filename.bml
; anything at http://www.dreamwidth.org/directory/filename.bml
will be here as htdocs/directory/filename.bml
, etc.
We are in the process of translating these files into controllers, found in cgi-bin/DW/Controller/
, and templates, found in views
.
logs
Some of the Dreamwidth sub-systems keep log files here, including the journal importer.
schemes
Template Toolkit (*.tt
) files for generating the site schemes used on Dreamwidth.
src
Source code for some of the packages the code uses. The [list of what gets checked out] says which files are pulled down to go in src/
. In that file the second column on lines 38 onwards lists destinations, so anything with src/*
in that column goes in src/
.
t
Tests that use the testing framework in main/test. See Dev Testing for how to use them.
temp
TODO: Probably used for temporary file storage, but what temporary files?
test
TODO: What's this?
views
Template Toolkit files which are gradually replacing the BML files. The controllers for the templates are in cgi-bin/DW/Controller/.