✨ Features implemented: - Smart inventory tracking with Hive database - Barcode scanning with auto-populated product info - Multiple API fallbacks (Open Food Facts, UPCItemDB) - Smart expiration date predictions by category - Discord webhook notifications (persisted) - Custom sage leaf vector icon - Material Design 3 UI with sage green theme - Privacy Policy & Terms of Service - Local-first, privacy-focused architecture 🎨 UI/UX: - Home dashboard with inventory stats - Add Item screen with barcode integration - Inventory list with expiration indicators - Settings with persistent preferences - About section with legal docs 🔧 Technical: - Flutter 3.35.5 with Riverpod state management - Hive 2.2.3 for local database - Mobile scanner for barcode detection - Feature-first architecture 🤖 Generated with Claude Code (https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
20 lines
672 B
C++
20 lines
672 B
C++
#ifndef RUNNER_UTILS_H_
|
|
#define RUNNER_UTILS_H_
|
|
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
// Creates a console for the process, and redirects stdout and stderr to
|
|
// it for both the runner and the Flutter library.
|
|
void CreateAndAttachConsole();
|
|
|
|
// Takes a null-terminated wchar_t* encoded in UTF-16 and returns a std::string
|
|
// encoded in UTF-8. Returns an empty std::string on failure.
|
|
std::string Utf8FromUtf16(const wchar_t* utf16_string);
|
|
|
|
// Gets the command line arguments passed in as a std::vector<std::string>,
|
|
// encoded in UTF-8. Returns an empty std::vector<std::string> on failure.
|
|
std::vector<std::string> GetCommandLineArguments();
|
|
|
|
#endif // RUNNER_UTILS_H_
|