Index: openacs-4/packages/file-storage/sql/postgresql/file-storage-package-create.sql =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/file-storage/sql/postgresql/file-storage-package-create.sql,v diff -u -r1.10 -r1.11 --- openacs-4/packages/file-storage/sql/postgresql/file-storage-package-create.sql 28 Aug 2003 09:41:53 -0000 1.10 +++ openacs-4/packages/file-storage/sql/postgresql/file-storage-package-create.sql 25 Sep 2003 12:30:22 -0000 1.11 @@ -94,7 +94,7 @@ if new_root_folder__folder_name is null then - v_folder_name := v_package_name || '' Root Folder ''; + v_folder_name := v_package_name || '' Root Folder''; else v_folder_name := new_root_folder__folder_name; end if; Index: openacs-4/packages/file-storage/tcl/file-storage-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/file-storage/tcl/file-storage-procs.tcl,v diff -u -r1.32 -r1.33 --- openacs-4/packages/file-storage/tcl/file-storage-procs.tcl 13 Aug 2003 11:14:35 -0000 1.32 +++ openacs-4/packages/file-storage/tcl/file-storage-procs.tcl 25 Sep 2003 12:30:22 -0000 1.33 @@ -286,8 +286,8 @@ remove unsafe file system characters. useful if you want to use $string as the name of an object to write to disk. } { - regsub -all {[<>:\"|/@#%&+\\]} $string {_} string - return $string + regsub -all {[<>:\"|/@\#%&+\\]} $string {_} string + return [string trim $string] } ad_proc -public folder_p { @@ -421,7 +421,7 @@ if {[string equal folder $type]} { set result [publish_folder_to_file_system -folder_id $object_id -path $path -folder_name $name -user_id $user_id] } elseif {[string equal url $type]} { - set result [publish_url -object_id $object_id -path $path -file_name $file_name] + set result [publish_url_to_file_system -object_id $object_id -path $path -file_name $file_name] } else { set result [publish_versioned_object_to_file_system -object_id $object_id -path $path] } @@ -465,7 +465,8 @@ {-path ""} {-file_name ""} } { - publish a url object to the file system + publish a url object to the file system as a Windows shortcut + (which at least KDE also knows how to handle) } { if {[empty_string_p $path]} { set path [ns_tmpnam] @@ -477,10 +478,12 @@ if {[empty_string_p $file_name]} { set file_name $label } + set file_name "${file_name}.url" set file_name [remove_special_file_system_characters -string $file_name] set fp [open [file join ${path} ${file_name}] w] - puts $fp url + puts $fp {[InternetShortcut]} + puts $fp URL=$url close $fp return [file join ${path} ${file_name}]