mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 03:12:44 +00:00 
			
		
		
		
	 746b8ec8de
			
		
	
	
		746b8ec8de
		
	
	
	
	
		
			
			Now the range A0:C4 in a sheet named "foo" can be represented as:
    R`sheet("foo"):A0:C4`
This makes it possible to do cross-sheet lookups and more.
		
	
			
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020-2022, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include "Forward.h"
 | |
| #include <LibJS/Forward.h>
 | |
| #include <LibJS/Runtime/Completion.h>
 | |
| #include <LibJS/Runtime/GlobalObject.h>
 | |
| 
 | |
| namespace Spreadsheet {
 | |
| 
 | |
| struct FunctionAndArgumentIndex {
 | |
|     String function_name;
 | |
|     size_t argument_index { 0 };
 | |
| };
 | |
| Optional<FunctionAndArgumentIndex> get_function_and_argument_index(StringView source);
 | |
| 
 | |
| class SheetGlobalObject final : public JS::GlobalObject {
 | |
|     JS_OBJECT(SheetGlobalObject, JS::GlobalObject);
 | |
| 
 | |
| public:
 | |
|     SheetGlobalObject(Sheet&);
 | |
| 
 | |
|     virtual ~SheetGlobalObject() override = default;
 | |
| 
 | |
|     virtual JS::ThrowCompletionOr<bool> internal_has_property(JS::PropertyKey const& name) const override;
 | |
|     virtual JS::ThrowCompletionOr<JS::Value> internal_get(JS::PropertyKey const&, JS::Value receiver) const override;
 | |
|     virtual JS::ThrowCompletionOr<bool> internal_set(JS::PropertyKey const&, JS::Value value, JS::Value receiver) override;
 | |
|     virtual void initialize_global_object() override;
 | |
| 
 | |
|     JS_DECLARE_NATIVE_FUNCTION(get_real_cell_contents);
 | |
|     JS_DECLARE_NATIVE_FUNCTION(set_real_cell_contents);
 | |
|     JS_DECLARE_NATIVE_FUNCTION(parse_cell_name);
 | |
|     JS_DECLARE_NATIVE_FUNCTION(current_cell_position);
 | |
|     JS_DECLARE_NATIVE_FUNCTION(column_index);
 | |
|     JS_DECLARE_NATIVE_FUNCTION(column_arithmetic);
 | |
|     JS_DECLARE_NATIVE_FUNCTION(get_column_bound);
 | |
|     JS_DECLARE_NATIVE_FUNCTION(get_name);
 | |
| 
 | |
| private:
 | |
|     virtual void visit_edges(Visitor&) override;
 | |
|     Sheet& m_sheet;
 | |
| };
 | |
| 
 | |
| class WorkbookObject final : public JS::Object {
 | |
|     JS_OBJECT(WorkbookObject, JS::Object);
 | |
| 
 | |
| public:
 | |
|     WorkbookObject(Workbook&, JS::GlobalObject&);
 | |
| 
 | |
|     virtual ~WorkbookObject() override = default;
 | |
| 
 | |
|     virtual void initialize(JS::GlobalObject&) override;
 | |
| 
 | |
|     JS_DECLARE_NATIVE_FUNCTION(sheet);
 | |
| 
 | |
| private:
 | |
|     virtual void visit_edges(Visitor&) override;
 | |
|     Workbook& m_workbook;
 | |
| };
 | |
| 
 | |
| }
 |