%% ``The contents of this file are subject to the Erlang Public License, %% Version 1.1, (the "License"); you may not use this file except in %% compliance with the License. You should have received a copy of the %% Erlang Public License along with this software. If not, it can be %% retrieved via the world wide web at http://www.erlang.org/. %% %% Software distributed under the License is distributed on an "AS IS" %% basis, WITHOUT WARRANTY OF ANY KIND, either expressed or implied. See %% the License for the specific language governing rights and limitations %% under the License. %% %% The Initial Developer of the Original Code is Ericsson Utvecklings AB. %% Portions created by Ericsson are Copyright 1999-2000, Ericsson %% Utvecklings AB. All Rights Reserved.'' %% %% $Id$ %% -module(docb_transform). -export([file/1, file/2]). %% file(File) -> ok | {error, Reason} %% file(File, Opts) -> ok | {error, Reason} %% File = string(), file name with or without ".xml" extension %% Opts = [Opt] %% Reason = badfile | {badopt, Term} file(File0) -> file(File0, []). file(File0, RawOpts) -> File = filename:rootname(File0), % without extension Ext = case filename:extension(File0) of ".xml" -> ".xml"; ".sgml" -> ".sgml"; "" -> %% If the file is given without extension, we try to %% infer if the source file is XML or SGML. %% SGML is supported *internally within OTP* for %% backwards compatibility reasons. case filelib:is_regular(File++".xml") of true -> ".xml"; false -> ".sgml" end; _Ext0 -> % this is probably an error... ".xml" end, case filelib:is_regular(File++Ext) of true -> case parse(RawOpts) of {ok, Opts0} -> {ok, Cwd} = file:get_cwd(), Opts = [{src_type,Ext}, {src_dir,Cwd}, {src_file,File}, {{local_defs,term},[]}, {{local_defs,cite},[]} | Opts0], case docb_main:process(File, Opts) of errors -> error; ok -> ok end; Error -> % {error, {badopt,Term}} Error end; false -> {error, badfile} end. parse(RawOpts) -> parse(RawOpts, []). %% Officially supported options parse([{html_mod,Module} | RawOpts], Opts) when is_atom(Module) -> parse(RawOpts, [{html_mod,Module} | Opts]); parse([{outdir,Dir} | RawOpts], Opts) when is_list(Dir) -> parse(RawOpts, [{outdir,Dir} | Opts]); parse([{number,N} | RawOpts], Opts) when is_integer(N) -> parse(RawOpts, [{number,integer_to_list(N)} | Opts]); parse([{number,Nstr} | RawOpts], Opts) -> % list when called from script parse(RawOpts, [{number,Nstr} | Opts]); parse([{ptype,Type} | RawOpts], Opts) when Type==unix; Type==windows -> parse(RawOpts, [{ptype,atom_to_list(Type)} | Opts]); parse([{ptype,Type} | RawOpts], Opts) -> % list when called from script parse(RawOpts, [{ptype,Type} | Opts]); parse([silent | RawOpts], Opts) -> put(option_silent, true), parse(RawOpts, [silent | Opts]); parse([{top,Index} | RawOpts], Opts) when is_list(Index) -> parse(RawOpts, [{top,Index} | Opts]); parse([{vsn,Vsn} | RawOpts], Opts) when is_list(Vsn) -> parse(RawOpts, [{vsn,Vsn} | Opts]); parse([{term_defs,File} | RawOpts], Opts) when is_list(File) -> Opts2 = get_defs(term, File, Opts), parse(RawOpts, Opts2); parse([{cite_defs,File} | RawOpts], Opts) when is_list(File) -> Opts2 = get_defs(cite, File, Opts), parse(RawOpts, Opts2); %% OTP internal options (SGML and PDF support etc.) parse([html | RawOpts], Opts) -> parse(RawOpts, [html | Opts]); parse([latex | RawOpts], Opts) -> parse(RawOpts, [latex | Opts]); parse([{man,Level} | RawOpts], Opts) -> % Level = 1..9 parse(RawOpts, [{man,Level} | Opts]); parse([{booksty,StyFile} | RawOpts], Opts) -> % "otpA4" | "otpBOOK" parse(RawOpts, [{booksty,StyFile} | Opts]); parse([{includepath,Dir} | RawOpts], Opts) -> parse(RawOpts, [{includepath,Dir} | Opts]); parse([showpaths | RawOpts], Opts) -> parse(RawOpts, [showpaths | Opts]); parse([straight | RawOpts], Opts) -> parse(RawOpts, [straight | Opts]); parse([{ent,Ent} | RawOpts], Opts) -> parse(RawOpts, [{ent,Ent} | Opts]); %% Undocumented options parse([{name, Name} | RawOpts], Opts) -> parse(RawOpts, [{name, Name} | Opts]); parse([framework_only | RawOpts], Opts) -> parse(RawOpts, [framework_only | Opts]); parse([kwicindex_only | RawOpts], Opts) -> parse(RawOpts, [kwicindex_only | Opts]); parse([], Opts) -> {ok, Opts}; parse([Opt | _RawOpts], _Opts) -> {error, {badopt, Opt}}. %% Type = term | cite get_defs(Type, File, Opts) -> Key = {defs,Type}, {PrevDefs, Opts2} = case lists:keysearch(Key, 1, Opts) of {value, {_, Defs0}} -> {Defs0, lists:keydelete(Key, 1, Opts)}; false -> {[], Opts} end, NewDefs = case file:consult(File) of {ok, [DefL]} when is_list(DefL) -> DefL; {ok, _Terms} -> docb_util:message(error, "Skipping defs file ~s, does " "not contain one list", [File]), []; {error, Error} -> Expl = lists:flatten(file:format_error(Error)), docb_util:message(error, "Skipping defs file ~s, ~s", [File, Expl]), [] end, [{Key,PrevDefs++NewDefs} | Opts2].