/* * Inkscape - an ambitious vector drawing program * * Authors: * Lauris Kaplinski * Frank Felfe * Davide Puricelli * Mitsuru Oka * Masatake YAMATO * F.J.Franklin * Michael Meeks * Chema Celorio * Pawel Palucha * ... and various people who have worked with various projects * Abhishek Sharma * * Copyright (C) 1999-2002 authors * Copyright (C) 2001-2002 Ximian, Inc. * * Inkscape authors: * Johan Ceuppens * * Copyright (C) 2004 Inkscape authors * * Released under GNU GPL, read the file 'COPYING' for more information */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include #include #include "document.h" #include "inkscape.h" #include "preferences.h" #ifdef ENABLE_NLS #include "helper/gettext.h" #endif #include "inkgc/gc-core.h" #include "io/sys.h" #include "svg-view-slideshow.h" #include "inkview-options-group.h" /** * @brief Get a list of valid SVG files from a list of strings * * @param[in] filenames The list of filenames/folders to check * @param[in] recursive True if we want to search within subfolders * @param[in] first_iteration True if this is the first iteration of the search * * @returns A new vector containing the complete paths for any valid SVG files */ std::vector get_valid_files(std::vector filenames, bool recursive = false, bool first_iteration = false) { // List to store all the valid files found by the search std::vector valid_files; // Loop through all the input filenames for(auto file : filenames) { // First check if the file actually exists. Skip to the next item if not if (!Inkscape::IO::file_test( file.c_str(), G_FILE_TEST_EXISTS )) { g_printerr("%s: %s\n", _("File or folder does not exist"), file.c_str()); continue; } // Now determine if this is a directory or a single file if (Inkscape::IO::file_test( file.c_str(), G_FILE_TEST_IS_DIR )) { // only recurse into directories if explicitly specified by user on command line or if recursive = true if (first_iteration || recursive) { std::vector new_filenames; Glib::Dir directory(file); for (auto new_file: directory) { new_filenames.emplace_back(Glib::build_filename(file, new_file)); } std::vector new_valid_files = get_valid_files(new_filenames, recursive); valid_files.insert(valid_files.end(), new_valid_files.begin(), new_valid_files.end()); } } else { if (!first_iteration) { // filter out files based on extension if they were not explicitly specified on command line Glib::ustring extension = file.substr( file.find_last_of(".") + 1 ); if (extension.compare("svg") && extension.compare("svgz")) { continue; } } // Try to create a new document from the contents of the file, and if it is valid // add the path to the list auto doc = SPDocument::createNewDoc(file.c_str(), TRUE, false); if(doc) { /* Append to list */ valid_files.push_back(file); } else { g_printerr("%s: %s\n", _("Could not open file"), file.c_str()); } } } return valid_files; } #ifdef WIN32 // minimal print handler (just prints the string to stdout) void g_print_no_convert(const gchar *buf) { fputs(buf, stdout); } void g_printerr_no_convert(const gchar *buf) { fputs(buf, stderr); } #endif int main (int argc, char **argv) { #ifdef WIN32 // Ugly hack to make g_print emit UTF-8 encoded characters. Otherwise glib will *always* // perform character conversion to the system's ANSI code page making UTF-8 output impossible. g_set_print_handler(g_print_no_convert); g_set_printerr_handler(g_print_no_convert); #endif #ifdef ENABLE_NLS Inkscape::initialize_gettext(); #endif Glib::OptionContext context(N_("- display SVG files")); context.set_summary(N_( "Quickly browse through a collection of .svg(z) files\n" "or show them as a slide show.")); context.set_description(N_( "Example:\n" " inkview -t 3 file1.svg file2.svgz series*.svg more_files")); context.set_translation_domain(GETTEXT_PACKAGE); InkviewOptionsGroup options; options.set_translation_domain(GETTEXT_PACKAGE); context.set_main_group(options); Gtk::Main main_instance(true); try { context.parse(argc, argv); } catch (const Glib::Error& ex) { g_printerr("%s\n\n", ex.what().c_str()); g_print("%s", context.get_help().c_str()); exit(EXIT_FAILURE); } LIBXML_TEST_VERSION Inkscape::GC::init(); Inkscape::Preferences::get(); // ensure preferences are initialized Inkscape::Application::create(argv[0], true); if(options.filenames.empty()) { g_print("%s", context.get_help().c_str()); exit(EXIT_FAILURE); } std::vector valid_files = get_valid_files(options.filenames, options.recursive, true); if(valid_files.empty()) { g_printerr("%s\n", _("No valid files to load.")); return 1; /* none of the slides loadable */ } SPSlideShow ss(valid_files, options.fullscreen, options.timer, options.scale); main_instance.run(); return 0; } /* Local Variables: mode:c++ c-file-style:"stroustrup" c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +)) indent-tabs-mode:nil fill-column:99 End: */ // vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4 :