Blame src/MacOSPath.ml

Packit 9ff65e
(******************************************************************************)
Packit 9ff65e
(*  ocaml-fileutils: files and filenames common operations                    *)
Packit 9ff65e
(*                                                                            *)
Packit 9ff65e
(*  Copyright (C) 2003-2014, Sylvain Le Gall                                  *)
Packit 9ff65e
(*                                                                            *)
Packit 9ff65e
(*  This library is free software; you can redistribute it and/or modify it   *)
Packit 9ff65e
(*  under the terms of the GNU Lesser General Public License as published by  *)
Packit 9ff65e
(*  the Free Software Foundation; either version 2.1 of the License, or (at   *)
Packit 9ff65e
(*  your option) any later version, with the OCaml static compilation         *)
Packit 9ff65e
(*  exception.                                                                *)
Packit 9ff65e
(*                                                                            *)
Packit 9ff65e
(*  This library is distributed in the hope that it will be useful, but       *)
Packit 9ff65e
(*  WITHOUT ANY WARRANTY; without even the implied warranty of                *)
Packit 9ff65e
(*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the file         *)
Packit 9ff65e
(*  COPYING for more details.                                                 *)
Packit 9ff65e
(*                                                                            *)
Packit 9ff65e
(*  You should have received a copy of the GNU Lesser General Public License  *)
Packit 9ff65e
(*  along with this library; if not, write to the Free Software Foundation,   *)
Packit 9ff65e
(*  Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA             *)
Packit 9ff65e
(******************************************************************************)
Packit 9ff65e
Packit 9ff65e
open FilePath_type
Packit 9ff65e
Packit 9ff65e
include CommonPath
Packit 9ff65e
Packit 9ff65e
Packit 9ff65e
let dir_writer lst =
Packit 9ff65e
 let buffer = Buffer.create path_length in
Packit 9ff65e
 let rec dir_writer_aux lst =
Packit 9ff65e
   match lst with
Packit 9ff65e
     Root s :: tl ->
Packit 9ff65e
       Buffer.add_string buffer s;
Packit 9ff65e
       Buffer.add_char   buffer ':';
Packit 9ff65e
       dir_writer_aux tl
Packit 9ff65e
   | (CurrentDir _) :: tl
Packit 9ff65e
   | ParentDir  :: tl ->
Packit 9ff65e
       Buffer.add_char   buffer ':';
Packit 9ff65e
       dir_writer_aux tl
Packit 9ff65e
   | (Component "") :: tl ->
Packit 9ff65e
       dir_writer_aux tl
Packit 9ff65e
   | (Component s) :: [] ->
Packit 9ff65e
       Buffer.add_string buffer s;
Packit 9ff65e
       dir_writer_aux []
Packit 9ff65e
   | (Component s) :: tl ->
Packit 9ff65e
       Buffer.add_string buffer s;
Packit 9ff65e
       Buffer.add_char   buffer ':';
Packit 9ff65e
       dir_writer_aux tl
Packit 9ff65e
   | [] ->
Packit 9ff65e
       Buffer.contents buffer
Packit 9ff65e
 in
Packit 9ff65e
   match lst with
Packit 9ff65e
     ParentDir :: _ -> dir_writer_aux ( (CurrentDir Long) :: lst )
Packit 9ff65e
   | [ CurrentDir Short ] -> ""
Packit 9ff65e
   | _ -> dir_writer_aux lst
Packit 9ff65e
Packit 9ff65e
Packit 9ff65e
let dir_reader str =
Packit 9ff65e
  let rec dir_reader_aux =
Packit 9ff65e
    function
Packit 9ff65e
    | [""] -> []
Packit 9ff65e
    | "" :: tl -> ParentDir :: (dir_reader_aux tl)
Packit 9ff65e
    | str :: tl -> Component str :: (dir_reader_aux tl)
Packit 9ff65e
    | [] -> []
Packit 9ff65e
  in
Packit 9ff65e
    match StringExt.split ~map:(fun s -> s) ':' str with
Packit 9ff65e
    | [] -> [CurrentDir Short]
Packit 9ff65e
    | "" :: tl -> CurrentDir Long :: (dir_reader_aux tl)
Packit 9ff65e
    | [id] -> [Component id]
Packit 9ff65e
    | root :: tl -> Root root :: (dir_reader_aux tl)
Packit 9ff65e
Packit 9ff65e
Packit 9ff65e
let path_writer lst = String.concat ";" lst
Packit 9ff65e
Packit 9ff65e
Packit 9ff65e
let path_reader = StringExt.split ~map:(fun s -> s) ';'